diff --git a/source/algorithms.tex b/source/algorithms.tex index f45ef17407..a51cc83868 100644 --- a/source/algorithms.tex +++ b/source/algorithms.tex @@ -62,14 +62,14 @@ \tcode{InputIterator1}, or \tcode{Input\-Iterator2}, the template argument shall meet the - \oldconcept{InputIterator} requirements\iref{input.iterators}. + \oldconceptref{InputIterator} requirements\iref{input.iterators}. \item If an algorithm's template parameter is named \tcode{OutputIterator}, \tcode{OutputIterator1}, or \tcode{Output\-Iterator2}, the template argument shall meet the - \oldconcept{OutputIterator} requirements\iref{output.iterators}. + \oldconceptref{OutputIterator} requirements\iref{output.iterators}. \item If an algorithm's template parameter is named \tcode{ForwardIterator}, @@ -77,7 +77,7 @@ \tcode{ForwardItera\-tor2}, or \tcode{NoThrowForwardIterator}, the template argument shall meet the - \oldconcept{ForwardIterator} requirements\iref{forward.iterators} + \oldconceptref{ForwardIterator} requirements\iref{forward.iterators} if it is required to be a mutable iterator, or model \libconcept{forward_iterator}\iref{iterator.concept.forward} otherwise. \item @@ -93,7 +93,7 @@ \tcode{Bidirectional\-Iterator1}, or \tcode{BidirectionalIterator2}, the template argument shall meet the - \oldconcept{BidirectionalIterator} requirements\iref{bidirectional.iterators} + \oldconceptref{BidirectionalIterator} requirements\iref{bidirectional.iterators} if it is required to be a mutable iterator, or model \libconcept{bidirectional_iterator}\iref{iterator.concept.bidir} otherwise. \item @@ -102,7 +102,7 @@ \tcode{Random\-AccessIterator1}, or \tcode{RandomAccessIterator2}, the template argument shall meet the - \oldconcept{RandomAccessIterator} requirements\iref{random.access.iterators} + \oldconceptref{RandomAccessIterator} requirements\iref{random.access.iterators} if it is required to be a mutable iterator, or model \libconcept{random_access_iterator}\iref{iterator.concept.random.access} otherwise. \end{itemize} @@ -3606,10 +3606,10 @@ \pnum \expects \tcode{Function} meets -the \oldconcept{MoveConstructible} requirements (\tref{cpp17.moveconstructible}). +the \oldconceptref{MoveConstructible} requirements (\tref{cpp17.moveconstructible}). \begin{note} \tcode{Function} need not meet the requirements of -\oldconcept{CopyConstructible} (\tref{cpp17.copyconstructible}). +\oldconceptref{CopyConstructible} (\tref{cpp17.copyconstructible}). \end{note} \pnum @@ -3646,7 +3646,7 @@ \begin{itemdescr} \pnum \expects -\tcode{Function} meets the \oldconcept{CopyConstructible} requirements. +\tcode{Function} meets the \oldconceptref{CopyConstructible} requirements. \pnum \effects @@ -3732,10 +3732,10 @@ \pnum \expects \tcode{n >= 0} is \tcode{true}. -\tcode{Function} meets the \oldconcept{MoveConstructible} requirements. +\tcode{Function} meets the \oldconceptref{MoveConstructible} requirements. \begin{note} \tcode{Function} need not meet -the requirements of \oldconcept{CopyConstructible}. +the requirements of \oldconceptref{CopyConstructible}. \end{note} \pnum @@ -3772,7 +3772,7 @@ \pnum \expects \tcode{n >= 0} is \tcode{true}. -\tcode{Function} meets the \oldconcept{CopyConstructible} requirements. +\tcode{Function} meets the \oldconceptref{CopyConstructible} requirements. \pnum \effects @@ -4438,7 +4438,7 @@ \item the types of \tcode{first1}, \tcode{last1}, \tcode{first2}, and \tcode{last2} meet the - \oldconcept{RandomAccessIterator} requirements\iref{random.access.iterators} + \oldconceptref{RandomAccessIterator} requirements\iref{random.access.iterators} and \tcode{last1 - first1 != last2 - first2} for the overloads in namespace \tcode{std}; \item @@ -4762,7 +4762,7 @@ \pnum \remarks -\tcode{Searcher} need not meet the \oldconcept{CopyConstructible} requirements. +\tcode{Searcher} need not meet the \oldconceptref{CopyConstructible} requirements. \end{itemdescr} \rSec2[alg.starts.with]{Starts with} @@ -5177,7 +5177,7 @@ For the overload with an \tcode{ExecutionPolicy}, there might be a performance cost if \tcode{iterator_traits::value_type} -is not \oldconcept{\-Move\-Constructible} (\tref{cpp17.moveconstructible}). +is not \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}). \end{note} \pnum @@ -5988,7 +5988,7 @@ \expects For the algorithms in namespace \tcode{std}, the type of \tcode{*first} -meets the \oldconcept{MoveAssignable} requirements (\tref{cpp17.moveassignable}). +meets the \oldconceptref{MoveAssignable} requirements (\tref{cpp17.moveassignable}). \pnum \effects @@ -6098,7 +6098,7 @@ For the overloads with an \tcode{ExecutionPolicy}, there might be a performance cost if \tcode{iterator_traits::value_type} does not meet -the \oldconcept{\-Move\-Constructible} (\tref{cpp17.moveconstructible}) requirements. +the \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) requirements. \end{note} \pnum @@ -6171,7 +6171,7 @@ For the overloads in namespace \tcode{std}, \tcode{pred} is an equivalence relation and the type of \tcode{*first} meets -the \oldconcept{MoveAssignable} requirements (\tref{cpp17.moveassignable}). +the \oldconceptref{MoveAssignable} requirements (\tref{cpp17.moveassignable}). \pnum \effects @@ -6274,18 +6274,18 @@ \libconcept{forward_iterator}\iref{iterator.concept.forward}, then there are no additional requirements for \tcode{T}. Otherwise, if \tcode{OutputIterator} meets - the \oldconcept{ForwardIterator} requirements and + the \oldconceptref{ForwardIterator} requirements and its value type is the same as \tcode{T}, then \tcode{T} meets - the \oldconcept{CopyAssignable} (\tref{cpp17.copyassignable}) requirements. + the \oldconceptref{CopyAssignable} (\tref{cpp17.copyassignable}) requirements. Otherwise, \tcode{T} meets both - the \oldconcept{CopyConstructible} (\tref{cpp17.copyconstructible}) and - \oldconcept{CopyAssignable} requirements. + the \oldconceptref{CopyConstructible} (\tref{cpp17.copyconstructible}) and + \oldconceptref{CopyAssignable} requirements. \begin{note} For the overloads with an \tcode{ExecutionPolicy}, there might be a performance cost if the value type of \tcode{ForwardIterator1} does not meet both the - \oldconcept{CopyConstructible} and \oldconcept{CopyAssignable} requirements. + \oldconceptref{CopyConstructible} and \oldconceptref{CopyAssignable} requirements. \end{note} \end{itemize} \end{itemize} @@ -6333,7 +6333,7 @@ \expects For the overloads in namespace \tcode{std}, \tcode{BidirectionalIterator} meets -the \oldconcept{Value\-Swappable} requirements\iref{swappable.requirements}. +the \oldconceptref{ValueSwappable} requirements\iref{swappable.requirements}. \pnum \effects @@ -6425,10 +6425,10 @@ \range{first}{middle} and \range{middle}{last} are valid ranges. For the overloads in namespace \tcode{std}, \tcode{ForwardIterator} meets -the \oldconcept{ValueSwappable} requirements\iref{swappable.requirements}, and +the \oldconceptref{ValueSwappable} requirements\iref{swappable.requirements}, and the type of \tcode{*first} meets -the \oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}) and -\oldconcept{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. +the \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) and +\oldconceptref{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. \pnum \effects @@ -6569,13 +6569,13 @@ \begin{itemize} \item \tcode{PopulationIterator} meets - the \oldconcept{InputIterator} requirements\iref{input.iterators}. + the \oldconceptref{InputIterator} requirements\iref{input.iterators}. \item \tcode{SampleIterator} meets - the \oldconcept{OutputIterator} requirements\iref{output.iterators}. + the \oldconceptref{OutputIterator} requirements\iref{output.iterators}. \item \tcode{SampleIterator} meets - the \oldconcept{RandomAccessIterator} requirements\iref{random.access.iterators} + the \oldconceptref{RandomAccessIterator} requirements\iref{random.access.iterators} unless \tcode{Pop\-ulat\-ion\-Iter\-ator} models \libconcept{forward_iterator}\iref{iterator.concept.forward}. \item @@ -6643,7 +6643,7 @@ \begin{itemize} \item \tcode{RandomAccessIterator} meets - the \oldconcept{ValueSwappable} requirements\iref{swappable.requirements}. + the \oldconceptref{ValueSwappable} requirements\iref{swappable.requirements}. \item The type \tcode{remove_reference_t} meets the uniform random bit generator\iref{rand.req.urng} requirements. @@ -6695,7 +6695,7 @@ \expects \tcode{n >= 0} is \tcode{true}. For the overloads in namespace \tcode{std}, -the type of \tcode{*first} meets the \oldconcept{MoveAssignable} requirements. +the type of \tcode{*first} meets the \oldconceptref{MoveAssignable} requirements. \pnum \effects @@ -6749,10 +6749,10 @@ \expects \tcode{n >= 0} is \tcode{true}. For the overloads in namespace \tcode{std}, -the type of \tcode{*first} meets the \oldconcept{MoveAssignable} requirements, +the type of \tcode{*first} meets the \oldconceptref{MoveAssignable} requirements, and \tcode{ForwardIterator} meets -the \oldconcept{BidirectionalIterator} requirements\iref{bidirectional.iterators} or -the \oldconcept{ValueSwap\-pable} requirements. +the \oldconceptref{BidirectionalIterator} requirements\iref{bidirectional.iterators} or +the \oldconceptref{ValueSwappable} requirements. \pnum \effects @@ -6766,7 +6766,7 @@ \item for the overload in namespace \tcode{std} without an \tcode{ExecutionPolicy} template parameter, -\tcode{Forward\-Iterator} meets the \oldconcept{BidirectionalIterator} requirements, +\tcode{Forward\-Iterator} meets the \oldconceptref{BidirectionalIterator} requirements, \item for the overloads in namespace \tcode{ranges}, \tcode{I} models \libconcept{bidirectional_iterator}. @@ -6922,10 +6922,10 @@ \expects For the overloads in namespace \tcode{std}, \tcode{RandomAccessIterator} meets -the \oldconcept{Value\-Swappable} requirements\iref{swappable.requirements} and +the \oldconceptref{ValueSwappable} requirements\iref{swappable.requirements} and the type of \tcode{*first} meets -the \oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}) and -\oldconcept{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. +the \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) and +\oldconceptref{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. \pnum \effects @@ -6980,10 +6980,10 @@ \expects For the overloads in namespace \tcode{std}, \tcode{RandomAccessIterator} meets -the \oldconcept{Value\-Swappable} requirements\iref{swappable.requirements} and +the \oldconceptref{ValueSwappable} requirements\iref{swappable.requirements} and the type of \tcode{*first} meets -the \oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}) and -\oldconcept{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. +the \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) and +\oldconceptref{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. \pnum \effects @@ -7050,10 +7050,10 @@ \range{first}{middle} and \range{middle}{last} are valid ranges. For the overloads in namespace \tcode{std}, \tcode{RandomAccessIterator} meets -the \oldconcept{ValueSwappable} requirements\iref{swappable.requirements} and +the \oldconceptref{ValueSwappable} requirements\iref{swappable.requirements} and the type of \tcode{*first} meets -the \oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}) and -\oldconcept{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. +the \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) and +\oldconceptref{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. \pnum \effects @@ -7158,10 +7158,10 @@ \expects For the overloads in namespace \tcode{std}, \tcode{RandomAccessIterator} meets -the \oldconcept{Value\-Swappable} requirements\iref{swappable.requirements}, +the \oldconceptref{ValueSwappable} requirements\iref{swappable.requirements}, the type of \tcode{*result_first} meets -the \oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}) and -\oldconcept{\-Move\-Assignable} (\tref{cpp17.moveassignable}) requirements. +the \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) and +\oldconceptref{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. \pnum For iterators \tcode{a1} and \tcode{b1} in \range{first}{last}, and @@ -7363,10 +7363,10 @@ \range{first}{nth} and \range{nth}{last} are valid ranges. For the overloads in namespace \tcode{std}, \tcode{RandomAccessIterator} meets -the \oldconcept{ValueSwappable} requirements\iref{swappable.requirements}, and +the \oldconceptref{ValueSwappable} requirements\iref{swappable.requirements}, and the type of \tcode{*first} meets -the \oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}) and -\oldconcept{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. +the \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) and +\oldconceptref{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. \pnum \effects @@ -7714,7 +7714,7 @@ \expects For the overloads in namespace \tcode{std}, \tcode{ForwardIterator} meets -the \oldconcept{ValueSwappable} requirements\iref{swappable.requirements}. +the \oldconceptref{ValueSwappable} requirements\iref{swappable.requirements}. \pnum \effects @@ -7741,7 +7741,7 @@ For the overload with no \tcode{ExecutionPolicy}, exactly $N$ applications of the predicate and projection. At most $N / 2$ swaps if the type of \tcode{first} meets - the \oldconcept{BidirectionalIterator} requirements + the \oldconceptref{BidirectionalIterator} requirements for the overloads in namespace \tcode{std} or models \libconcept{bidirectional_iterator} for the overloads in namespace \tcode{ranges}, @@ -7783,10 +7783,10 @@ \expects For the overloads in namespace \tcode{std}, \tcode{BidirectionalIterator} meets -the \oldconcept{Value\-Swappable} requirements\iref{swappable.requirements} and +the \oldconceptref{ValueSwappable} requirements\iref{swappable.requirements} and the type of \tcode{*first} meets -the \oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}) and -\oldconcept{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. +the \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) and +\oldconceptref{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. \pnum \effects @@ -7869,7 +7869,7 @@ \begin{note} For the overload with an \tcode{ExecutionPolicy}, there might be a performance cost if \tcode{first}'s value type -does not meet the \oldconcept{CopyConstructible} requirements. +does not meet the \oldconceptref{CopyConstructible} requirements. \end{note} \pnum @@ -8074,10 +8074,10 @@ sorted with respect to \tcode{comp} and \tcode{proj}. For the overloads in namespace \tcode{std}, \tcode{BidirectionalIterator} meets -the \oldconcept{Value\-Swappable} requirements\iref{swappable.requirements} and +the \oldconceptref{ValueSwappable} requirements\iref{swappable.requirements} and the type of \tcode{*first} meets -the \oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}) and -\oldconcept{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. +the \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) and +\oldconceptref{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. \pnum \effects @@ -8643,10 +8643,10 @@ is a valid heap with respect to \tcode{comp} and \tcode{proj}. For the overloads in namespace \tcode{std}, \tcode{RandomAccessIterator} meets -the \oldconcept{ValueSwappable} requirements\iref{swappable.requirements} and +the \oldconceptref{ValueSwappable} requirements\iref{swappable.requirements} and the type of \tcode{*first} meets -the \oldconcept{MoveConstructible} requirements (\tref{cpp17.moveconstructible}) and -the \oldconcept{MoveAssignable} requirements (\tref{cpp17.moveassignable}). +the \oldconceptref{MoveConstructible} requirements (\tref{cpp17.moveconstructible}) and +the \oldconceptref{MoveAssignable} requirements (\tref{cpp17.moveassignable}). \pnum \effects @@ -8696,10 +8696,10 @@ is a valid non-empty heap with respect to \tcode{comp} and \tcode{proj}. For the overloads in namespace \tcode{std}, \tcode{RandomAccessIterator} meets -the \oldconcept{ValueSwappable} requirements\iref{swappable.requirements} and +the \oldconceptref{ValueSwappable} requirements\iref{swappable.requirements} and the type of \tcode{*first} meets -the \oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}) and -\oldconcept{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. +the \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) and +\oldconceptref{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. \pnum \effects @@ -8752,10 +8752,10 @@ \expects For the overloads in namespace \tcode{std}, \tcode{RandomAccessIterator} meets -the \oldconcept{ValueSwap\-pable} requirements\iref{swappable.requirements} and +the \oldconceptref{ValueSwappable} requirements\iref{swappable.requirements} and the type of \tcode{*first} meets -the \oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}) and -\oldconcept{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. +the \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) and +\oldconceptref{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. \pnum \effects @@ -8805,10 +8805,10 @@ a valid heap with respect to \tcode{comp} and \tcode{proj}. For the overloads in namespace \tcode{std}, \tcode{RandomAccessIterator} meets -the \oldconcept{ValueSwappable} requirements\iref{swappable.requirements} and +the \oldconceptref{ValueSwappable} requirements\iref{swappable.requirements} and the type of \tcode{*first} meets -the \oldconcept{MoveConst\-ruct\-ible} (\tref{cpp17.moveconstructible}) and -\oldconcept{Move\-Assign\-able} (\tref{cpp17.moveassignable}) requirements. +the \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) and +\oldconceptref{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. \pnum \effects @@ -8967,7 +8967,7 @@ \pnum \expects For the first form, \tcode{T} meets the -\oldconcept{LessThanComparable} requirements (\tref{cpp17.lessthancomparable}). +\oldconceptref{LessThanComparable} requirements (\tref{cpp17.lessthancomparable}). \pnum \returns @@ -9007,8 +9007,8 @@ \expects \tcode{ranges::distance(r) > 0}. For the overloads in namespace \tcode{std}, -\tcode{T} meets the \oldconcept{\-Copy\-Constructible} requirements. -For the first form, \tcode{T} meets the \oldconcept{LessThanComparable} +\tcode{T} meets the \oldconceptref{CopyConstructible} requirements. +For the first form, \tcode{T} meets the \oldconceptref{LessThanComparable} requirements (\tref{cpp17.lessthancomparable}). \pnum @@ -9045,7 +9045,7 @@ \pnum \expects For the first form, \tcode{T} meets the -\oldconcept{LessThanComparable} requirements (\tref{cpp17.lessthancomparable}). +\oldconceptref{LessThanComparable} requirements (\tref{cpp17.lessthancomparable}). \pnum \returns @@ -9085,8 +9085,8 @@ \expects \tcode{ranges::distance(r) > 0}. For the overloads in namespace \tcode{std}, -\tcode{T} meets the \oldconcept{\-Copy\-Constructible} requirements. -For the first form, \tcode{T} meets the \oldconcept{LessThanComparable} +\tcode{T} meets the \oldconceptref{CopyConstructible} requirements. +For the first form, \tcode{T} meets the \oldconceptref{LessThanComparable} requirements (\tref{cpp17.lessthancomparable}). \pnum @@ -9125,7 +9125,7 @@ \pnum \expects For the first form, \tcode{T} meets the -\oldconcept{LessThanComparable} requirements (\tref{cpp17.lessthancomparable}). +\oldconceptref{LessThanComparable} requirements (\tref{cpp17.lessthancomparable}). \pnum \returns @@ -9166,8 +9166,8 @@ \expects \tcode{ranges::distance(r) > 0}. For the overloads in namespace \tcode{std}, -\tcode{T} meets the \oldconcept{\-Copy\-Constructible} requirements. -For the first form, type \tcode{T} meets the \oldconcept{LessThanComparable} +\tcode{T} meets the \oldconceptref{CopyConstructible} requirements. +For the first form, type \tcode{T} meets the \oldconceptref{LessThanComparable} requirements (\tref{cpp17.lessthancomparable}). \pnum @@ -9359,7 +9359,7 @@ \expects \tcode{bool(invoke(comp, invoke(proj, hi), invoke(proj, lo)))} is \tcode{false}. For the first form, type \tcode{T} -meets the \oldconcept{LessThan\-Comparable} +meets the \oldconceptref{LessThanComparable} requirements (\tref{cpp17.lessthancomparable}). \pnum @@ -9548,7 +9548,7 @@ \expects For the overloads in namespace \tcode{std}, \tcode{BidirectionalIterator} meets -the \oldconcept{Value\-Swappable} requirements\iref{swappable.requirements}. +the \oldconceptref{ValueSwappable} requirements\iref{swappable.requirements}. \pnum \effects @@ -9607,7 +9607,7 @@ \expects For the overloads in namespace \tcode{std}, \tcode{BidirectionalIterator} meets -the \oldconcept{Value\-Swappable} requirements\iref{swappable.requirements}. +the \oldconceptref{ValueSwappable} requirements\iref{swappable.requirements}. \pnum \effects @@ -9925,8 +9925,8 @@ \pnum \expects \tcode{T} meets -the \oldconcept{CopyConstructible} (\tref{cpp17.copyconstructible}) -and \oldconcept{CopyAssignable} (\tref{cpp17.copyassignable}) requirements. +the \oldconceptref{CopyConstructible} (\tref{cpp17.copyconstructible}) +and \oldconceptref{CopyAssignable} (\tref{cpp17.copyassignable}) requirements. In the range \crange{first}{last}, \tcode{binary_op} neither modifies elements nor invalidates iterators or subranges. @@ -10048,7 +10048,7 @@ \expects \begin{itemize} \item - \tcode{T} meets the \oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}) requirements. + \tcode{T} meets the \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) requirements. \item \tcode{binary_op} neither invalidates iterators or subranges, nor modifies elements in the range \crange{first}{last}. @@ -10092,8 +10092,8 @@ \pnum \expects \tcode{T} meets -the \oldconcept{CopyConstructible} (\tref{cpp17.copyconstructible}) -and \oldconcept{CopyAssignable} (\tref{cpp17.copyassignable}) requirements. +the \oldconceptref{CopyConstructible} (\tref{cpp17.copyconstructible}) +and \oldconceptref{CopyAssignable} (\tref{cpp17.copyassignable}) requirements. In the ranges \crange{first1}{last1} and \crange{first2}{first2 + (last1 - first1)} \tcode{binary_op1} and \tcode{binary_op2} @@ -10188,7 +10188,7 @@ \expects \begin{itemize} \item - \tcode{T} meets the \oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}) requirements. + \tcode{T} meets the \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) requirements. \item Neither \tcode{binary_op1} nor \tcode{binary_op2} invalidates subranges, nor modifies elements in the ranges @@ -10238,7 +10238,7 @@ \expects \begin{itemize} \item - \tcode{T} meets the \oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}) requirements. + \tcode{T} meets the \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) requirements. \item Neither \tcode{unary_op} nor \tcode{binary_op} invalidates subranges, nor modifies elements in the range \crange{first}{last}. @@ -10387,7 +10387,7 @@ \expects \begin{itemize} \item - \tcode{T} meets the \oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}) requirements. + \tcode{T} meets the \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) requirements. \item \tcode{binary_op} neither invalidates iterators or subranges, nor modifies elements in @@ -10508,9 +10508,9 @@ \begin{itemize} \item If \tcode{init} is provided, - \tcode{T} meets the \oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}) requirements; + \tcode{T} meets the \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) requirements; otherwise, \tcode{U} - meets the \oldconcept{MoveConstructible} requirements. + meets the \oldconceptref{MoveConstructible} requirements. \item \tcode{binary_op} neither invalidates iterators or subranges, nor modifies elements in @@ -10587,7 +10587,7 @@ \expects \begin{itemize} \item - \tcode{T} meets the \oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}) requirements. + \tcode{T} meets the \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) requirements. \item Neither \tcode{unary_op} nor \tcode{binary_op} invalidates iterators or subranges, nor modifies elements in @@ -10686,9 +10686,9 @@ \begin{itemize} \item If \tcode{init} is provided, \tcode{T} meets the - \oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}) requirements; + \oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) requirements; otherwise, \tcode{U} meets the - \oldconcept{MoveConstructible} requirements. + \oldconceptref{MoveConstructible} requirements. \item Neither \tcode{unary_op} nor \tcode{binary_op} invalidates iterators or subranges, nor modifies elements in @@ -10787,7 +10787,7 @@ \begin{itemize} \item For the overloads with no \tcode{ExecutionPolicy}, - \tcode{T} meets the \oldconcept{MoveAssignable} (\tref{cpp17.moveassignable}) + \tcode{T} meets the \oldconceptref{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. \item For all overloads, in the ranges \crange{first}{last} diff --git a/source/concepts.tex b/source/concepts.tex index 0bfd861231..b166e3a9bf 100644 --- a/source/concepts.tex +++ b/source/concepts.tex @@ -495,7 +495,7 @@ template concept @\deflibconcept{unsigned_integral}@ = @\libconcept{integral}@ && !@\libconcept{signed_integral}@; template - concept @\deflibconcept{floating_point}@ = @\libglobalref{is_floating_point_v}@; + concept @\deflibconcept{floating_point}@ = is_floating_point_v; \end{itemdecl} \begin{itemdescr} @@ -747,7 +747,7 @@ \begin{itemdescr} \pnum \begin{note} -Unlike the \oldconcept{Destructible} requirements~(\tref{cpp17.destructible}), this +Unlike the \oldconceptref{Destructible} requirements~(\tref{cpp17.destructible}), this concept forbids destructors that are potentially throwing, even if a particular invocation of the destructor does not actually throw. \end{note} diff --git a/source/diagnostics.tex b/source/diagnostics.tex index b729a13d73..be9f913a24 100644 --- a/source/diagnostics.tex +++ b/source/diagnostics.tex @@ -834,9 +834,9 @@ // \ref{syserr}, system error support template - constexpr bool @\libglobal{is_error_code_enum_v}@ = is_error_code_enum::value; + constexpr bool @\libglobal{is_error_code_enum_v}@ = @\libglobalref{is_error_code_enum}@::value; template - constexpr bool is_error_condition_enum_v = is_error_condition_enum::value; + constexpr bool @\libglobal{is_error_condition_enum_v}@ = @\libglobalref{is_error_condition_enum}@::value; } \end{codeblock} @@ -847,9 +847,9 @@ exposes the \libheader{cerrno} macros is unspecified. \pnum -The \tcode{is_error_code_enum} and \tcode{is_error_condition_enum} templates may be +The \libglobalref{is_error_code_enum} and \libglobalref{is_error_condition_enum} templates may be specialized for program-defined types to indicate that such types are eligible -for \tcode{class error_code} and \tcode{class error_condition} implicit +for \tcode{class \libglobalref{error_code}} and \tcode{class \libglobalref{error_condition}} implicit conversions, respectively. \rSec2[syserr.errcat]{Class \tcode{error_category}} @@ -874,8 +874,6 @@ \indexlibraryglobal{error_category}% \indexlibraryctor{error_category}% \indexlibrarydtor{error_category}% -\indexlibraryglobal{generic_category}% -\indexlibraryglobal{system_category}% \begin{codeblock} namespace std { class error_category { @@ -894,8 +892,8 @@ strong_ordering operator<=>(const error_category& rhs) const noexcept; }; - const error_category& generic_category() noexcept; - const error_category& system_category() noexcept; + const error_category& @\libglobal{generic_category}@() noexcept; + const error_category& @\libglobal{system_category}@() noexcept; } \end{codeblock} @@ -1166,7 +1164,7 @@ \begin{itemdescr} \pnum \constraints -\tcode{is_error_code_enum_v} is \tcode{true}. +\tcode{\libglobalref{is_error_code_enum_v}} is \tcode{true}. \pnum \effects @@ -1199,7 +1197,7 @@ \begin{itemdescr} \pnum \constraints -\tcode{is_error_code_enum_v} is \tcode{true}. +\tcode{\libglobalref{is_error_code_enum_v}} is \tcode{true}. \pnum \effects diff --git a/source/exec.tex b/source/exec.tex index e4bb77d9db..65eeb1c3fb 100644 --- a/source/exec.tex +++ b/source/exec.tex @@ -31,25 +31,25 @@ \capsep core & provide core execution functionality, and connection between core components & - e.g., \tcode{connect}, \tcode{start} \\ + e.g., \libglobalref{connect}, \libglobalref{start} \\ completion functions & called by senders to announce the completion of the work (success, error, or cancellation) & - \tcode{set_value}, \tcode{set_error}, \tcode{set_stopped} \\ + \libglobalref{set_value}, \libglobalref{set_error}, \libglobalref{set_stopped} \\ senders & allow the specialization of the provided sender algorithms & \begin{itemize} - \item sender factories (e.g., \tcode{schedule}, \tcode{just}, \tcode{read_env}) - \item sender adaptors (e.g., \tcode{continues_on}, \tcode{then}, \tcode{let_value}) - \item sender consumers (e.g., \tcode{sync_wait}) + \item sender factories (e.g., \libglobalref{schedule}, \libglobalref{just}, \libglobalref{read_env}) + \item sender adaptors (e.g., \libglobalref{continues_on}, \libglobalref{then}, \libglobalref{let_value}) + \item sender consumers (e.g., \libglobalref{sync_wait}) \end{itemize} \\ queries & allow querying different properties of objects & \begin{itemize} - \item general queries (e.g., \tcode{get_allocator}, \tcode{get_stop_token}) - \item environment queries (e.g., \tcode{get_scheduler}, \tcode{get_delegation_scheduler}) - \item scheduler queries (e.g., \tcode{get_forward_progress_guarantee}) - \item sender attribute queries (e.g., \tcode{get_completion_scheduler}) + \item general queries (e.g., \libglobalref{get_allocator}, \libglobalref{get_stop_token}) + \item environment queries (e.g., \tcode{get_scheduler}, \libglobalref{get_delegation_scheduler}) + \item scheduler queries (e.g., \libglobalref{get_forward_progress_guarantee}) + \item sender attribute queries (e.g., \libglobalref{get_completion_scheduler}) \end{itemize} \\ \end{floattable} diff --git a/source/future.tex b/source/future.tex index 136559313b..c743592710 100644 --- a/source/future.tex +++ b/source/future.tex @@ -351,7 +351,7 @@ \pnum \remarks -\tcode{is_pod} is a \oldconcept{UnaryTypeTrait}\iref{meta.rqmts} +\tcode{is_pod} is a \oldconceptref{UnaryTypeTrait}\iref{meta.rqmts} with a base characteristic of \tcode{true_type} if \tcode{T} is a POD type, and \tcode{false_type} otherwise. @@ -535,7 +535,7 @@ If the expression \tcode{TS::value} is well-formed when treated as an \deflink{unevaluated operand}{expr.context}, then specializations of each of the two templates meet -the \oldconcept{TransformationTrait} requirements with a base characteristic of +the \oldconceptref{TransformationTrait} requirements with a base characteristic of \tcode{integral_constant}. Otherwise, they have no member \tcode{value}. @@ -563,7 +563,7 @@ Let \tcode{TE} denote \tcode{tuple_element_t} of the cv-unqualified type \tcode{T}. Then specializations of each of the two templates meet -the \oldconcept{TransformationTrait} requirements +the \oldconceptref{TransformationTrait} requirements with a member typedef \tcode{type} that names the following type: \begin{itemize} \item for the first specialization, \tcode{add_volatile_t}, and @@ -603,7 +603,7 @@ Let \tcode{VS} denote \tcode{variant_size} of the cv-unqualified type \tcode{T}. Then specializations of each of the two templates meet -the \oldconcept{UnaryTypeTrait} requirements +the \oldconceptref{UnaryTypeTrait} requirements with a base characteristic of \tcode{integral_constant}. \end{itemdescr} @@ -617,7 +617,7 @@ Let \tcode{VA} denote \tcode{variant_alternative} of the cv-unqualified type \tcode{T}. Then specializations of each of the two templates meet -the \oldconcept{TransformationTrait} requirements +the \oldconceptref{TransformationTrait} requirements with a member typedef \tcode{type} that names the following type: \begin{itemize} \item for the first specialization, \tcode{add_volatile_t}, and diff --git a/source/iostreams.tex b/source/iostreams.tex index 6951313a6b..0c9ade0a94 100644 --- a/source/iostreams.tex +++ b/source/iostreams.tex @@ -1681,10 +1681,10 @@ It holds a state object whose type is equal to the template parameter \tcode{stateT}. Type \tcode{stateT} shall meet -the \oldconcept{DefaultConstructible} (\tref{cpp17.defaultconstructible}), -\oldconcept{CopyConstructible} (\tref{cpp17.copyconstructible}), -\oldconcept{CopyAssignable} (\tref{cpp17.copyassignable}), and -\oldconcept{Destructible} (\tref{cpp17.destructible}) requirements. +the \oldconceptref{DefaultConstructible} (\tref{cpp17.defaultconstructible}), +\oldconceptref{CopyConstructible} (\tref{cpp17.copyconstructible}), +\oldconceptref{CopyAssignable} (\tref{cpp17.copyassignable}), and +\oldconceptref{Destructible} (\tref{cpp17.destructible}) requirements. If \tcode{is_trivially_copy_constructible_v} is \tcode{true}, then \tcode{fpos} has a trivial copy constructor. If \tcode{is_trivially_copy_assignable_v} is \tcode{true}, @@ -1692,11 +1692,11 @@ If \tcode{is_trivially_destructible_v} is \tcode{true}, then \tcode{fpos} has a trivial destructor. All specializations of \tcode{fpos} meet -the \oldconcept{DefaultConstructible}, -\oldconcept{CopyConstructible}, -\oldconcept{CopyAssignable}, -\oldconcept{Destructible}, -and \oldconcept{EqualityComparable} (\tref{cpp17.equalitycomparable}) requirements. +the \oldconceptref{DefaultConstructible}, +\oldconceptref{CopyConstructible}, +\oldconceptref{CopyAssignable}, +\oldconceptref{Destructible}, +and \oldconceptref{EqualityComparable} (\tref{cpp17.equalitycomparable}) requirements. In addition, the expressions shown in \tref{fpos.operations} are valid and have the indicated semantics. In that table, @@ -12945,7 +12945,7 @@ \pnum \tcode{Allocator} shall meet -the \oldconcept{Allocator} requirements\iref{allocator.requirements.general}. +the \oldconceptref{Allocator} requirements\iref{allocator.requirements.general}. \pnum \begin{example} @@ -13238,7 +13238,7 @@ \pnum Template parameters named \tcode{InputIterator} shall meet the -\oldconcept{InputIterator} requirements\iref{input.iterators} and shall +\oldconceptref{InputIterator} requirements\iref{input.iterators} and shall have a value type that is one of the encoded character types. \pnum @@ -13252,7 +13252,7 @@ \pnum Template parameters named \tcode{Allocator} shall meet -the \oldconcept{Allocator} requirements\iref{allocator.requirements.general}. +the \oldconceptref{Allocator} requirements\iref{allocator.requirements.general}. \rSec2[fs.filesystem.syn]{Header \tcode{} synopsis} @@ -14065,7 +14065,7 @@ \item \tcode{basic_string_view}. A function argument \tcode{const Source\&} \tcode{source} shall have an effective range \range{source.begin()}{source.end()}. -\item A type meeting the \oldconcept{InputIterator} requirements that iterates over a NTCTS\@. +\item A type meeting the \oldconceptref{InputIterator} requirements that iterates over a NTCTS\@. The value type shall be an encoded character type. A function argument \tcode{const Source\&} \tcode{source} shall have an effective range \range{source}{end} where \tcode{end} is the first @@ -16545,7 +16545,7 @@ \pnum \tcode{directory_iterator} meets the -\oldconcept{InputIterator} requirements\iref{input.iterators}. +\oldconceptref{InputIterator} requirements\iref{input.iterators}. \pnum If an iterator of type \tcode{directory_iterator} reports an error or diff --git a/source/lib-intro.tex b/source/lib-intro.tex index ffeb3db172..07d67a8ce8 100644 --- a/source/lib-intro.tex +++ b/source/lib-intro.tex @@ -1809,7 +1809,7 @@ }\\ \end{oldconcepttable} -\begin{oldconcepttable}{CopyConstructible}{ (in addition to \oldconcept{MoveConstructible})}{cpp17.copyconstructible} +\begin{oldconcepttable}{CopyConstructible}{ (in addition to \oldconceptref{MoveConstructible})}{cpp17.copyconstructible} {p{1in}p{4.15in}} \topline \hdstyle{Expression} & \hdstyle{Post-condition} \\ \capsep @@ -1836,7 +1836,7 @@ }\\ \end{oldconcepttable} -\begin{oldconcepttable}{CopyAssignable}{ (in addition to \oldconcept{MoveAssignable})}{cpp17.copyassignable} +\begin{oldconcepttable}{CopyAssignable}{ (in addition to \oldconceptref{MoveAssignable})}{cpp17.copyassignable} {p{1in}p{1in}p{1in}p{1.9in}} \topline \hdstyle{Expression} & \hdstyle{Return type} & \hdstyle{Return value} & \hdstyle{Post-condition} \\ \capsep @@ -1850,7 +1850,7 @@ \tcode{u.\~T()} & All resources owned by \tcode{u} are reclaimed, no exception is propagated. \\ \rowsep \multicolumn{2}{|l|}{ \begin{tailnote} - Array types and non-object types are not \oldconcept{Destructible}. + Array types and non-object types are not \oldconceptref{Destructible}. \end{tailnote} } \\ \end{oldconcepttable} @@ -1929,7 +1929,7 @@ // for rvalues and lvalues } -// Preconditions: \tcode{T} meets the \oldconcept{Swappable} requirements. +// Preconditions: \tcode{T} meets the \oldconceptref{Swappable} requirements. template void lv_swap(T& t1, T& t2) { using std::swap; @@ -1966,9 +1966,9 @@ A \oldconcept{NullablePointer} type is a pointer-like type that supports null values. A type \tcode{P} meets the \oldconcept{\-Nullable\-Pointer} requirements if \begin{itemize} -\item \tcode{P} meets the \oldconcept{EqualityComparable}, -\oldconcept{DefaultConstructible}, \oldconcept{CopyConstructible}, \oldconcept{\-Copy\-Assign\-able}, -\oldconcept{Swappable}, and \oldconcept{Destructible} requirements, +\item \tcode{P} meets the \oldconceptref{EqualityComparable}, +\oldconceptref{DefaultConstructible}, \oldconceptref{CopyConstructible}, \oldconcept{\-Copy\-Assign\-able}, +\oldconceptref{Swappable}, and \oldconceptref{Destructible} requirements, \item the expressions shown in \tref{cpp17.nullablepointer} are valid and have the indicated semantics, and @@ -2044,8 +2044,8 @@ A type \tcode{H} meets the \defnoldconcept{Hash} requirements if \begin{itemize} \item it is a function object type\iref{function.objects}, -\item it meets the \oldconcept{CopyConstructible} (\tref{cpp17.copyconstructible}) and - \oldconcept{Destructible} (\tref{cpp17.destructible}) requirements, and +\item it meets the \oldconceptref{CopyConstructible} (\tref{cpp17.copyconstructible}) and + \oldconceptref{Destructible} (\tref{cpp17.destructible}) requirements, and \item the expressions shown in \tref{cpp17.hash} are valid and have the indicated semantics. \end{itemize} @@ -2729,7 +2729,7 @@ \tcode{true_type} only if an allocator of type \tcode{X} should be copied when the client container is copy-assigned; if so, \tcode{X} shall meet -the \oldconcept{CopyAssignable} requirements (\tref{cpp17.copyassignable}) and +the \oldconceptref{CopyAssignable} requirements (\tref{cpp17.copyassignable}) and the copy operation shall not throw exceptions. \pnum @@ -2751,7 +2751,7 @@ \tcode{true_type} only if an allocator of type \tcode{X} should be moved when the client container is move-assigned; if so, \tcode{X} shall meet -the \oldconcept{MoveAssignable} requirements (\tref{cpp17.moveassignable}) and +the \oldconceptref{MoveAssignable} requirements (\tref{cpp17.moveassignable}) and the move operation shall not throw exceptions. \pnum @@ -2773,7 +2773,7 @@ \tcode{true_type} only if an allocator of type \tcode{X} should be swapped when the client container is swapped; if so, -\tcode{X} shall meet the \oldconcept{Swappable} requirements\iref{swappable.requirements} and +\tcode{X} shall meet the \oldconceptref{Swappable} requirements\iref{swappable.requirements} and the \tcode{swap} operation shall not throw exceptions. \pnum @@ -2803,7 +2803,7 @@ \pnum An allocator type \tcode{X} shall meet the -\oldconcept{CopyConstructible} requirements (\tref{cpp17.copyconstructible}). +\oldconceptref{CopyConstructible} requirements (\tref{cpp17.copyconstructible}). The \tcode{XX::pointer}, \tcode{XX::const_pointer}, \tcode{XX::void_pointer}, and \tcode{XX::const_void_pointer} types shall meet the \oldconcept{Nullable\-Pointer} requirements (\tref{cpp17.nullablepointer}). @@ -2811,7 +2811,7 @@ comparison operator function, copy operation, move operation, or swap operation on these pointer types shall exit via an exception. \tcode{XX::pointer} and \tcode{XX::const_pointer} shall also meet the requirements for -a \oldconcept{RandomAccessIterator}\iref{random.access.iterators} and +a \oldconceptref{RandomAccessIterator}\iref{random.access.iterators} and the additional requirement that, when \tcode{p} and \tcode{(p + n)} are dereferenceable pointer values for some integral value \tcode{n}, \begin{codeblock} diff --git a/source/memory.tex b/source/memory.tex index 47a0dcbec4..cd1d4682da 100644 --- a/source/memory.tex +++ b/source/memory.tex @@ -1005,7 +1005,7 @@ disambiguate constructor and function overloading. Specifically, several types (see \tcode{tuple}~\ref{tuple}) have constructors with \tcode{allocator_arg_t} as the first argument, immediately followed by an argument of a type that meets the -\oldconcept{Allocator} requirements\iref{allocator.requirements.general}. +\oldconceptref{Allocator} requirements\iref{allocator.requirements.general}. \rSec2[allocator.uses]{\tcode{uses_allocator}} @@ -1020,7 +1020,7 @@ \pnum \remarks Automatically detects whether \tcode{T} has a nested \tcode{allocator_type} that -is convertible from \tcode{Alloc}. Meets the \oldconcept{BinaryTypeTrait} +is convertible from \tcode{Alloc}. Meets the \oldconceptref{BinaryTypeTrait} requirements\iref{meta.rqmts}. The implementation shall provide a definition that is derived from \tcode{true_type} if the \grammarterm{qualified-id} \tcode{T::allocator_type} is valid and denotes a type\iref{temp.deduct} and @@ -1945,8 +1945,8 @@ Each object of a type \tcode{U} instantiated from the \tcode{unique_ptr} template specified in \ref{unique.ptr} has the strict ownership semantics, specified above, of a unique pointer. In partial satisfaction of these semantics, each such \tcode{U} -is \oldconcept{MoveConstructible} and \oldconcept{MoveAssignable}, but is not -\oldconcept{CopyConstructible} nor \oldconcept{CopyAssignable}. +is \oldconceptref{MoveConstructible} and \oldconceptref{MoveAssignable}, but is not +\oldconceptref{CopyConstructible} nor \oldconceptref{CopyAssignable}. The template parameter \tcode{T} of \tcode{unique_ptr} may be an incomplete type. \pnum @@ -2133,7 +2133,7 @@ \pnum If the deleter's type \tcode{D} is not a reference type, \tcode{D} shall meet -the \oldconcept{Destructible} requirements (\tref{cpp17.destructible}). +the \oldconceptref{Destructible} requirements (\tref{cpp17.destructible}). \pnum If the \grammarterm{qualified-id} \tcode{remove_reference_t::pointer} is valid and denotes a @@ -2141,7 +2141,7 @@ D>::pointer} shall be a synonym for \tcode{remove_reference_t::pointer}. Otherwise \tcode{unique_ptr::pointer} shall be a synonym for \tcode{element_type*}. The type \tcode{unique_ptr::pointer} shall -meet the \oldconcept{NullablePointer} requirements (\tref{cpp17.nullablepointer}). +meet the \oldconceptref{NullablePointer} requirements (\tref{cpp17.nullablepointer}). \pnum \begin{example} @@ -2167,7 +2167,7 @@ \pnum \expects -\tcode{D} meets the \oldconcept{DefaultConstructible} requirements (\tref{cpp17.defaultconstructible}), +\tcode{D} meets the \oldconceptref{DefaultConstructible} requirements (\tref{cpp17.defaultconstructible}), and that construction does not throw an exception. \pnum @@ -2194,7 +2194,7 @@ \pnum \expects -\tcode{D} meets the \oldconcept{DefaultConstructible} requirements (\tref{cpp17.defaultconstructible}), +\tcode{D} meets the \oldconceptref{DefaultConstructible} requirements (\tref{cpp17.defaultconstructible}), and that construction does not throw an exception. \pnum @@ -2223,10 +2223,10 @@ \pnum \expects For the first constructor, if \tcode{D} is not a reference type, -\tcode{D} meets the \oldconcept{CopyConstructible} requirements and +\tcode{D} meets the \oldconceptref{CopyConstructible} requirements and such construction does not exit via an exception. For the second constructor, if \tcode{D} is not a reference type, -\tcode{D} meets the \oldconcept{MoveConstructible} requirements and +\tcode{D} meets the \oldconceptref{MoveConstructible} requirements and such construction does not exit via an exception. \pnum @@ -2251,8 +2251,8 @@ \begin{example} \begin{codeblock} D d; -unique_ptr p1(new int, D()); // \tcode{D} must be \oldconcept{MoveConstructible} -unique_ptr p2(new int, d); // \tcode{D} must be \oldconcept{CopyConstructible} +unique_ptr p1(new int, D()); // \tcode{D} must be \oldconceptref{MoveConstructible} +unique_ptr p2(new int, d); // \tcode{D} must be \oldconceptref{CopyConstructible} unique_ptr p3(new int, d); // \tcode{p3} holds a reference to \tcode{d} unique_ptr p4(new int, D()); // error: rvalue deleter object combined // with reference deleter type @@ -2273,7 +2273,7 @@ \pnum \expects If \tcode{D} is not a reference type, -\tcode{D} meets the \oldconcept{MoveConstructible} +\tcode{D} meets the \oldconceptref{MoveConstructible} requirements (\tref{cpp17.moveconstructible}). Construction of the deleter from an rvalue of type \tcode{D} does not @@ -2382,10 +2382,10 @@ \pnum \expects If \tcode{D} is not a reference type, \tcode{D} meets the -\oldconcept{MoveAssignable} requirements (\tref{cpp17.moveassignable}) and assignment +\oldconceptref{MoveAssignable} requirements (\tref{cpp17.moveassignable}) and assignment of the deleter from an rvalue of type \tcode{D} does not throw an exception. Otherwise, \tcode{D} is a reference type; -\tcode{remove_reference_t} meets the \oldconcept{CopyAssignable} +\tcode{remove_reference_t} meets the \oldconceptref{CopyAssignable} requirements and assignment of the deleter from an lvalue of type \tcode{D} does not throw an exception. @@ -3283,8 +3283,8 @@ \end{codeblock} \pnum -Specializations of \tcode{shared_ptr} shall be \oldconcept{CopyConstructible}, -\oldconcept{CopyAssignable}, and \oldconcept{\-Less\-Than\-Comparable}, allowing their use in standard +Specializations of \tcode{shared_ptr} shall be \oldconceptref{CopyConstructible}, +\oldconceptref{CopyAssignable}, and \oldconceptref{LessThanComparable}, allowing their use in standard containers. Specializations of \tcode{shared_ptr} shall be contextually convertible to \tcode{bool}, allowing their use in boolean expressions and declarations in conditions. @@ -3429,7 +3429,7 @@ The expression \tcode{d(p)} has well-defined behavior and does not throw exceptions. \tcode{A} meets -the \oldconcept{Allocator} requirements\iref{allocator.requirements.general}. +the \oldconceptref{Allocator} requirements\iref{allocator.requirements.general}. \pnum \effects @@ -3946,7 +3946,7 @@ \pnum \expects \tcode{A} meets -the \oldconcept{Allocator} requirements\iref{allocator.requirements.general}. +the \oldconceptref{Allocator} requirements\iref{allocator.requirements.general}. \pnum \effects @@ -4602,8 +4602,8 @@ \end{codeblock} \pnum -Specializations of \tcode{weak_ptr} shall be \oldconcept{CopyConstructible} and -\oldconcept{CopyAssignable}, allowing their use in standard +Specializations of \tcode{weak_ptr} shall be \oldconceptref{CopyConstructible} and +\oldconceptref{CopyAssignable}, allowing their use in standard containers. The template parameter \tcode{T} of \tcode{weak_ptr} may be an incomplete type. @@ -5182,7 +5182,7 @@ \end{codeblock} \pnum -\tcode{Pointer} shall meet the \oldconcept{NullablePointer} requirements. +\tcode{Pointer} shall meet the \oldconceptref{NullablePointer} requirements. If \tcode{Smart} is a specialization of \tcode{shared_ptr} and \tcode{sizeof...(Args) == 0}, the program is ill-formed. @@ -5422,7 +5422,7 @@ \end{codeblock} \pnum -\tcode{Pointer} shall meet the \oldconcept{NullablePointer} requirements. +\tcode{Pointer} shall meet the \oldconceptref{NullablePointer} requirements. If \tcode{Smart} is a specialization of \tcode{shared_ptr}, the program is ill-formed. \begin{note} diff --git a/source/meta.tex b/source/meta.tex index f8ed03cbc6..b6d69967c1 100644 --- a/source/meta.tex +++ b/source/meta.tex @@ -94,12 +94,12 @@ A \defnoldconcept{UnaryTypeTrait} describes a property of a type. It shall be a class template that takes one template type argument and, optionally, additional arguments that help define the -property being described. It shall be \oldconcept{DefaultConstructible}, -\oldconcept{CopyConstructible}, +property being described. It shall be \oldconceptref{DefaultConstructible}, +\oldconceptref{CopyConstructible}, and publicly and unambiguously derived, directly or indirectly, from its \defn{base characteristic}, which is a specialization of the template -\tcode{integral_constant}\iref{meta.help}, with +\libglobalref{integral_constant}, with the arguments to the template \tcode{integral_constant} determined by the requirements for the particular property being described. The member names of the base characteristic shall not be hidden and shall be @@ -110,12 +110,12 @@ relationship between two types. It shall be a class template that takes two template type arguments and, optionally, additional arguments that help define the relationship being described. It shall -be \oldconcept{DefaultConstructible}, \oldconcept{CopyConstructible}, +be \oldconceptref{DefaultConstructible}, \oldconceptref{CopyConstructible}, and publicly and unambiguously derived, directly or indirectly, from its \term{base characteristic}, which is a specialization of the template -\tcode{integral_constant}\iref{meta.help}, with +\libglobalref{integral_constant}, with the arguments to the template \tcode{integral_constant} determined by the requirements for the particular relationship being described. The member names of the base characteristic shall not be hidden and shall be @@ -282,17 +282,17 @@ template struct add_cv; template - using @\libglobal{remove_const_t}@ = typename remove_const::type; + using @\libglobal{remove_const_t}@ = typename @\libglobalref{remove_const}@::type; template - using @\libglobal{remove_volatile_t}@ = typename remove_volatile::type; + using @\libglobal{remove_volatile_t}@ = typename @\libglobalref{remove_volatile}@::type; template - using @\libglobal{remove_cv_t}@ = typename remove_cv::type; + using @\libglobal{remove_cv_t}@ = typename @\libglobalref{remove_cv}@::type; template - using @\libglobal{add_const_t}@ = typename add_const::type; + using @\libglobal{add_const_t}@ = typename @\libglobalref{add_const}@::type; template - using @\libglobal{add_volatile_t}@ = typename add_volatile::type; + using @\libglobal{add_volatile_t}@ = typename @\libglobalref{add_volatile}@::type; template - using @\libglobal{add_cv_t}@ = typename add_cv::type; + using @\libglobal{add_cv_t}@ = typename @\libglobalref{add_cv}@::type; // \ref{meta.trans.ref}, reference modifications template struct remove_reference; @@ -300,38 +300,38 @@ template struct add_rvalue_reference; template - using @\libglobal{remove_reference_t}@ = typename remove_reference::type; + using @\libglobal{remove_reference_t}@ = typename @\libglobalref{remove_reference}@::type; template - using @\libglobal{add_lvalue_reference_t}@ = typename add_lvalue_reference::type; + using @\libglobal{add_lvalue_reference_t}@ = typename @\libglobalref{add_lvalue_reference}@::type; template - using @\libglobal{add_rvalue_reference_t}@ = typename add_rvalue_reference::type; + using @\libglobal{add_rvalue_reference_t}@ = typename @\libglobalref{add_rvalue_reference}@::type; // \ref{meta.trans.sign}, sign modifications template struct make_signed; template struct make_unsigned; template - using @\libglobal{make_signed_t}@ = typename make_signed::type; + using @\libglobal{make_signed_t}@ = typename @\libglobalref{make_signed}@::type; template - using @\libglobal{make_unsigned_t}@ = typename make_unsigned::type; + using @\libglobal{make_unsigned_t}@ = typename @\libglobalref{make_unsigned}@::type; // \ref{meta.trans.arr}, array modifications template struct remove_extent; template struct remove_all_extents; template - using @\libglobal{remove_extent_t}@ = typename remove_extent::type; + using @\libglobal{remove_extent_t}@ = typename @\libglobalref{remove_extent}@::type; template - using @\libglobal{remove_all_extents_t}@ = typename remove_all_extents::type; + using @\libglobal{remove_all_extents_t}@ = typename @\libglobalref{remove_all_extents}@::type; // \ref{meta.trans.ptr}, pointer modifications template struct remove_pointer; template struct add_pointer; template - using @\libglobal{remove_pointer_t}@ = typename remove_pointer::type; + using @\libglobal{remove_pointer_t}@ = typename @\libglobalref{remove_pointer}@::type; template - using @\libglobal{add_pointer_t}@ = typename add_pointer::type; + using @\libglobal{add_pointer_t}@ = typename @\libglobalref{add_pointer}@::type; // \ref{meta.trans.other}, other transformations template struct type_identity; @@ -349,27 +349,27 @@ template struct unwrap_ref_decay; template - using @\libglobal{type_identity_t}@ = typename type_identity::type; + using @\libglobal{type_identity_t}@ = typename @\libglobalref{type_identity}@::type; template - using @\libglobal{remove_cvref_t}@ = typename remove_cvref::type; + using @\libglobal{remove_cvref_t}@ = typename @\libglobalref{remove_cvref}@::type; template - using @\libglobal{decay_t}@ = typename decay::type; + using @\libglobal{decay_t}@ = typename @\libglobalref{decay}@::type; template - using @\libglobal{enable_if_t}@ = typename enable_if::type; + using @\libglobal{enable_if_t}@ = typename @\libglobalref{enable_if}@::type; template - using @\libglobal{conditional_t}@ = typename conditional::type; + using @\libglobal{conditional_t}@ = typename @\libglobalref{conditional}@::type; template - using @\libglobal{common_type_t}@ = typename common_type::type; + using @\libglobal{common_type_t}@ = typename @\libglobalref{common_type}@::type; template - using @\libglobal{common_reference_t}@ = typename common_reference::type; + using @\libglobal{common_reference_t}@ = typename @\libglobalref{common_reference}@::type; template - using @\libglobal{underlying_type_t}@ = typename underlying_type::type; + using @\libglobal{underlying_type_t}@ = typename @\libglobalref{underlying_type}@::type; template - using @\libglobal{invoke_result_t}@ = typename invoke_result::type; + using @\libglobal{invoke_result_t}@ = typename @\libglobalref{invoke_result}@::type; template - using unwrap_reference_t = typename unwrap_reference::type; + using @\libglobal{unwrap_reference_t}@ = typename @\libglobalref{unwrap_reference}@::type; template - using unwrap_ref_decay_t = typename unwrap_ref_decay::type; + using @\libglobal{unwrap_ref_decay_t}@ = typename @\libglobalref{unwrap_ref_decay}@::type; template using @\libglobal{void_t}@ = void; @@ -380,200 +380,200 @@ // \ref{meta.unary.cat}, primary type categories template - constexpr bool @\libglobal{is_void_v}@ = is_void::value; + constexpr bool @\libglobal{is_void_v}@ = @\libglobalref{is_void}@::value; template - constexpr bool @\libglobal{is_null_pointer_v}@ = is_null_pointer::value; + constexpr bool @\libglobal{is_null_pointer_v}@ = @\libglobalref{is_null_pointer}@::value; template - constexpr bool @\libglobal{is_integral_v}@ = is_integral::value; + constexpr bool @\libglobal{is_integral_v}@ = @\libglobalref{is_integral}@::value; template - constexpr bool @\libglobal{is_floating_point_v}@ = is_floating_point::value; + constexpr bool @\libglobal{is_floating_point_v}@ = @\libglobalref{is_floating_point}@::value; template - constexpr bool @\libglobal{is_array_v}@ = is_array::value; + constexpr bool @\libglobal{is_array_v}@ = @\libglobalref{is_array}@::value; template - constexpr bool @\libglobal{is_pointer_v}@ = is_pointer::value; + constexpr bool @\libglobal{is_pointer_v}@ = @\libglobalref{is_pointer}@::value; template - constexpr bool @\libglobal{is_lvalue_reference_v}@ = is_lvalue_reference::value; + constexpr bool @\libglobal{is_lvalue_reference_v}@ = @\libglobalref{is_lvalue_reference}@::value; template - constexpr bool @\libglobal{is_rvalue_reference_v}@ = is_rvalue_reference::value; + constexpr bool @\libglobal{is_rvalue_reference_v}@ = @\libglobalref{is_rvalue_reference}@::value; template - constexpr bool @\libglobal{is_member_object_pointer_v}@ = is_member_object_pointer::value; + constexpr bool @\libglobal{is_member_object_pointer_v}@ = @\libglobalref{is_member_object_pointer}@::value; template - constexpr bool @\libglobal{is_member_function_pointer_v}@ = is_member_function_pointer::value; + constexpr bool @\libglobal{is_member_function_pointer_v}@ = @\libglobalref{is_member_function_pointer}@::value; template - constexpr bool @\libglobal{is_enum_v}@ = is_enum::value; + constexpr bool @\libglobal{is_enum_v}@ = @\libglobalref{is_enum}@::value; template - constexpr bool @\libglobal{is_union_v}@ = is_union::value; + constexpr bool @\libglobal{is_union_v}@ = @\libglobalref{is_union}@::value; template - constexpr bool @\libglobal{is_class_v}@ = is_class::value; + constexpr bool @\libglobal{is_class_v}@ = @\libglobalref{is_class}@::value; template - constexpr bool @\libglobal{is_function_v}@ = is_function::value; + constexpr bool @\libglobal{is_function_v}@ = @\libglobalref{is_function}@::value; // \ref{meta.unary.comp}, composite type categories template - constexpr bool @\libglobal{is_reference_v}@ = is_reference::value; + constexpr bool @\libglobal{is_reference_v}@ = @\libglobalref{is_reference}@::value; template - constexpr bool @\libglobal{is_arithmetic_v}@ = is_arithmetic::value; + constexpr bool @\libglobal{is_arithmetic_v}@ = @\libglobalref{is_arithmetic}@::value; template - constexpr bool @\libglobal{is_fundamental_v}@ = is_fundamental::value; + constexpr bool @\libglobal{is_fundamental_v}@ = @\libglobalref{is_fundamental}@::value; template - constexpr bool @\libglobal{is_object_v}@ = is_object::value; + constexpr bool @\libglobal{is_object_v}@ = @\libglobalref{is_object}@::value; template - constexpr bool @\libglobal{is_scalar_v}@ = is_scalar::value; + constexpr bool @\libglobal{is_scalar_v}@ = @\libglobalref{is_scalar}@::value; template - constexpr bool @\libglobal{is_compound_v}@ = is_compound::value; + constexpr bool @\libglobal{is_compound_v}@ = @\libglobalref{is_compound}@::value; template - constexpr bool @\libglobal{is_member_pointer_v}@ = is_member_pointer::value; + constexpr bool @\libglobal{is_member_pointer_v}@ = @\libglobalref{is_member_pointer}@::value; // \ref{meta.unary.prop}, type properties template - constexpr bool @\libglobal{is_const_v}@ = is_const::value; + constexpr bool @\libglobal{is_const_v}@ = @\libglobalref{is_const}@::value; template - constexpr bool @\libglobal{is_volatile_v}@ = is_volatile::value; + constexpr bool @\libglobal{is_volatile_v}@ = @\libglobalref{is_volatile}@::value; template - constexpr bool @\libglobal{is_trivially_copyable_v}@ = is_trivially_copyable::value; + constexpr bool @\libglobal{is_trivially_copyable_v}@ = @\libglobalref{is_trivially_copyable}@::value; template - constexpr bool @\libglobal{is_standard_layout_v}@ = is_standard_layout::value; + constexpr bool @\libglobal{is_standard_layout_v}@ = @\libglobalref{is_standard_layout}@::value; template constexpr bool @\libglobal{is_empty_v}@ = is_empty::value; template - constexpr bool @\libglobal{is_polymorphic_v}@ = is_polymorphic::value; + constexpr bool @\libglobal{is_polymorphic_v}@ = @\libglobalref{is_polymorphic}@::value; template - constexpr bool @\libglobal{is_abstract_v}@ = is_abstract::value; + constexpr bool @\libglobal{is_abstract_v}@ = @\libglobalref{is_abstract}@::value; template - constexpr bool @\libglobal{is_final_v}@ = is_final::value; + constexpr bool @\libglobal{is_final_v}@ = @\libglobalref{is_final}@::value; template - constexpr bool @\libglobal{is_aggregate_v}@ = is_aggregate::value; + constexpr bool @\libglobal{is_aggregate_v}@ = @\libglobalref{is_aggregate}@::value; template constexpr bool @\libglobal{is_signed_v}@ = is_signed::value; template - constexpr bool @\libglobal{is_unsigned_v}@ = is_unsigned::value; + constexpr bool @\libglobal{is_unsigned_v}@ = @\libglobalref{is_unsigned}@::value; template - constexpr bool @\libglobal{is_bounded_array_v}@ = is_bounded_array::value; + constexpr bool @\libglobal{is_bounded_array_v}@ = @\libglobalref{is_bounded_array}@::value; template - constexpr bool @\libglobal{is_unbounded_array_v}@ = is_unbounded_array::value; + constexpr bool @\libglobal{is_unbounded_array_v}@ = @\libglobalref{is_unbounded_array}@::value; template - constexpr bool @\libglobal{is_scoped_enum_v}@ = is_scoped_enum::value; + constexpr bool @\libglobal{is_scoped_enum_v}@ = @\libglobalref{is_scoped_enum}@::value; template - constexpr bool @\libglobal{is_constructible_v}@ = is_constructible::value; + constexpr bool @\libglobal{is_constructible_v}@ = @\libglobalref{is_constructible}@::value; template - constexpr bool @\libglobal{is_default_constructible_v}@ = is_default_constructible::value; + constexpr bool @\libglobal{is_default_constructible_v}@ = @\libglobalref{is_default_constructible}@::value; template - constexpr bool @\libglobal{is_copy_constructible_v}@ = is_copy_constructible::value; + constexpr bool @\libglobal{is_copy_constructible_v}@ = @\libglobalref{is_copy_constructible}@::value; template - constexpr bool @\libglobal{is_move_constructible_v}@ = is_move_constructible::value; + constexpr bool @\libglobal{is_move_constructible_v}@ = @\libglobalref{is_move_constructible}@::value; template - constexpr bool @\libglobal{is_assignable_v}@ = is_assignable::value; + constexpr bool @\libglobal{is_assignable_v}@ = @\libglobalref{is_assignable}@::value; template - constexpr bool @\libglobal{is_copy_assignable_v}@ = is_copy_assignable::value; + constexpr bool @\libglobal{is_copy_assignable_v}@ = @\libglobalref{is_copy_assignable}@::value; template - constexpr bool @\libglobal{is_move_assignable_v}@ = is_move_assignable::value; + constexpr bool @\libglobal{is_move_assignable_v}@ = @\libglobalref{is_move_assignable}@::value; template - constexpr bool @\libglobal{is_swappable_with_v}@ = is_swappable_with::value; + constexpr bool @\libglobal{is_swappable_with_v}@ = @\libglobalref{is_swappable_with}@::value; template - constexpr bool @\libglobal{is_swappable_v}@ = is_swappable::value; + constexpr bool @\libglobal{is_swappable_v}@ = @\libglobalref{is_swappable}@::value; template - constexpr bool @\libglobal{is_destructible_v}@ = is_destructible::value; + constexpr bool @\libglobal{is_destructible_v}@ = @\libglobalref{is_destructible}@::value; template - constexpr bool is_trivially_constructible_v - = is_trivially_constructible::value; + constexpr @\libglobal{bool is_trivially_constructible_v}@ + = @\libglobalref{is_trivially_constructible}@::value; template - constexpr bool is_trivially_default_constructible_v - = is_trivially_default_constructible::value; + constexpr bool @\libglobal{is_trivially_default_constructible_v}@ + = @\libglobalref{is_trivially_default_constructible}@::value; template - constexpr bool is_trivially_copy_constructible_v - = is_trivially_copy_constructible::value; + constexpr bool @\libglobal{is_trivially_copy_constructible_v}@ + = @\libglobalref{is_trivially_copy_constructible}@::value; template - constexpr bool is_trivially_move_constructible_v - = is_trivially_move_constructible::value; + constexpr bool @\libglobal{is_trivially_move_constructible_v}@ + = @\libglobalref{is_trivially_move_constructible}@::value; template - constexpr bool @\libglobal{is_trivially_assignable_v}@ = is_trivially_assignable::value; + constexpr bool @\libglobal{is_trivially_assignable_v}@ = @\libglobalref{is_trivially_assignable}@::value; template - constexpr bool is_trivially_copy_assignable_v - = is_trivially_copy_assignable::value; + constexpr bool @\libglobal{is_trivially_copy_assignable_v}@ + = @\libglobalref{is_trivially_copy_assignable}@::value; template - constexpr bool is_trivially_move_assignable_v - = is_trivially_move_assignable::value; + constexpr bool @\libglobal{is_trivially_move_assignable_v}@ + = @\libglobalref{is_trivially_move_assignable}@::value; template - constexpr bool @\libglobal{is_trivially_destructible_v}@ = is_trivially_destructible::value; + constexpr bool @\libglobal{is_trivially_destructible_v}@ = @\libglobalref{is_trivially_destructible}@::value; template - constexpr bool is_nothrow_constructible_v - = is_nothrow_constructible::value; + constexpr bool @\libglobal{is_nothrow_constructible_v}@ + = @\libglobalref{is_nothrow_constructible}@::value; template - constexpr bool is_nothrow_default_constructible_v - = is_nothrow_default_constructible::value; + constexpr bool @\libglobal{is_nothrow_default_constructible_v}@ + = @\libglobalref{is_nothrow_default_constructible}@::value; template - constexpr bool is_nothrow_copy_constructible_v - = is_nothrow_copy_constructible::value; + constexpr bool @\libglobal{is_nothrow_copy_constructible_v}@ + = @\libglobalref{is_nothrow_copy_constructible}@::value; template - constexpr bool is_nothrow_move_constructible_v - = is_nothrow_move_constructible::value; + constexpr bool @\libglobal{is_nothrow_move_constructible_v}@ + = @\libglobalref{is_nothrow_move_constructible}@::value; template - constexpr bool @\libglobal{is_nothrow_assignable_v}@ = is_nothrow_assignable::value; + constexpr bool @\libglobal{is_nothrow_assignable_v}@ = @\libglobalref{is_nothrow_assignable}@::value; template - constexpr bool @\libglobal{is_nothrow_copy_assignable_v}@ = is_nothrow_copy_assignable::value; + constexpr bool @\libglobal{is_nothrow_copy_assignable_v}@ = @\libglobalref{is_nothrow_copy_assignable}@::value; template - constexpr bool @\libglobal{is_nothrow_move_assignable_v}@ = is_nothrow_move_assignable::value; + constexpr bool @\libglobal{is_nothrow_move_assignable_v}@ = @\libglobalref{is_nothrow_move_assignable}@::value; template - constexpr bool @\libglobal{is_nothrow_swappable_with_v}@ = is_nothrow_swappable_with::value; + constexpr bool @\libglobal{is_nothrow_swappable_with_v}@ = @\libglobalref{is_nothrow_swappable_with}@::value; template - constexpr bool @\libglobal{is_nothrow_swappable_v}@ = is_nothrow_swappable::value; + constexpr bool @\libglobal{is_nothrow_swappable_v}@ = @\libglobalref{is_nothrow_swappable}@::value; template - constexpr bool @\libglobal{is_nothrow_destructible_v}@ = is_nothrow_destructible::value; + constexpr bool @\libglobal{is_nothrow_destructible_v}@ = @\libglobalref{is_nothrow_destructible}@::value; template - constexpr bool @\libglobal{is_implicit_lifetime_v}@ = is_implicit_lifetime::value; + constexpr bool @\libglobal{is_implicit_lifetime_v}@ = @\libglobalref{is_implicit_lifetime}@::value; template - constexpr bool @\libglobal{has_virtual_destructor_v}@ = has_virtual_destructor::value; + constexpr bool @\libglobal{has_virtual_destructor_v}@ = @\libglobalref{has_virtual_destructor}@::value; template - constexpr bool has_unique_object_representations_v - = has_unique_object_representations::value; + constexpr bool @\libglobal{has_unique_object_representations_v}@ + = @\libglobalref{has_unique_object_representations}@::value; template constexpr bool @\libglobal{reference_constructs_from_temporary_v}@ - = reference_constructs_from_temporary::value; + = @\libglobalref{reference_constructs_from_temporary}@::value; template constexpr bool @\libglobal{reference_converts_from_temporary_v}@ - = reference_converts_from_temporary::value; + = @\libglobalref{reference_converts_from_temporary}@::value; // \ref{meta.unary.prop.query}, type property queries template - constexpr size_t @\libglobal{alignment_of_v}@ = alignment_of::value; + constexpr size_t @\libglobal{alignment_of_v}@ = @\libglobalref{alignment_of}@::value; template - constexpr size_t @\libglobal{rank_v}@ = rank::value; + constexpr size_t @\libglobal{rank_v}@ = @\libglobalref{rank}@::value; template - constexpr size_t @\libglobal{extent_v}@ = extent::value; + constexpr size_t @\libglobal{extent_v}@ = @\libglobalref{extent}@::value; // \ref{meta.rel}, type relations template - constexpr bool @\libglobal{is_same_v}@ = is_same::value; + constexpr bool @\libglobal{is_same_v}@ = @\libglobalref{is_same}@::value; template - constexpr bool @\libglobal{is_base_of_v}@ = is_base_of::value; + constexpr bool @\libglobal{is_base_of_v}@ = @\libglobalref{is_base_of}@::value; template - constexpr bool @\libglobal{is_virtual_base_of_v}@ = is_virtual_base_of::value; + constexpr bool @\libglobal{is_virtual_base_of_v}@ = @\libglobalref{is_virtual_base_of}@::value; template - constexpr bool @\libglobal{is_convertible_v}@ = is_convertible::value; + constexpr bool @\libglobal{is_convertible_v}@ = @\libglobalref{is_convertible}@::value; template - constexpr bool @\libglobal{is_nothrow_convertible_v}@ = is_nothrow_convertible::value; + constexpr bool @\libglobal{is_nothrow_convertible_v}@ = @\libglobalref{is_nothrow_convertible}@::value; template - constexpr bool @\libglobal{is_layout_compatible_v}@ = is_layout_compatible::value; + constexpr bool @\libglobal{is_layout_compatible_v}@ = @\libglobalref{is_layout_compatible}@::value; template - constexpr bool is_pointer_interconvertible_base_of_v - = is_pointer_interconvertible_base_of::value; + constexpr bool @\libglobal{is_pointer_interconvertible_base_of_v}@ + = @\libglobalref{is_pointer_interconvertible_base_of}@::value; template - constexpr bool @\libglobal{is_invocable_v}@ = is_invocable::value; + constexpr bool @\libglobal{is_invocable_v}@ = @\libglobalref{is_invocable}@::value; template - constexpr bool @\libglobal{is_invocable_r_v}@ = is_invocable_r::value; + constexpr bool @\libglobal{is_invocable_r_v}@ = @\libglobalref{is_invocable_r}@::value; template - constexpr bool @\libglobal{is_nothrow_invocable_v}@ = is_nothrow_invocable::value; + constexpr bool @\libglobal{is_nothrow_invocable_v}@ = @\libglobalref{is_nothrow_invocable}@::value; template constexpr bool is_nothrow_invocable_r_v - = is_nothrow_invocable_r::value; + = @\libglobalref{is_nothrow_invocable_r}@::value; // \ref{meta.logical}, logical operator traits template - constexpr bool @\libglobal{conjunction_v}@ = conjunction::value; + constexpr bool @\libglobal{conjunction_v}@ = @\libglobalref{conjunction}@::value; template - constexpr bool @\libglobal{disjunction_v}@ = disjunction::value; + constexpr bool @\libglobal{disjunction_v}@ = @\libglobalref{disjunction}@::value; template - constexpr bool @\libglobal{negation_v}@ = negation::value; + constexpr bool @\libglobal{negation_v}@ = @\libglobalref{negation}@::value; // \ref{meta.member}, member relationships template @@ -625,7 +625,7 @@ \pnum Each of these templates shall be a -\oldconcept{UnaryTypeTrait}\iref{meta.rqmts} +\oldconceptref{UnaryTypeTrait} with a base characteristic of \tcode{true_type} if the corresponding condition is \tcode{true}, otherwise \tcode{false_type}. @@ -655,17 +655,14 @@ \topline \lhdr{Template} & \chdr{Condition} & \rhdr{Comments} \\ \capsep \endhead -\indexlibraryglobal{is_void}% \tcode{template}\br - \tcode{struct is_void;} & + \tcode{struct \libglobal{is_void};} & \tcode{T} is \keyword{void} & \\ \rowsep -\indexlibraryglobal{is_null_pointer}% \tcode{template}\br - \tcode{struct is_null_pointer;} & + \tcode{struct \libglobal{is_null_pointer};} & \tcode{T} is \tcode{nullptr_t}\iref{basic.fundamental} & \\ \rowsep -\indexlibraryglobal{is_integral}% \tcode{template}\br - \tcode{struct is_integral;} & + \tcode{struct \libglobal{is_integral};} & \tcode{T} is an integral type\iref{basic.fundamental} & \\ \rowsep \indexlibraryglobal{is_floating_point}% \tcode{template}\br @@ -864,9 +861,8 @@ \tcode{T} is an abstract class\iref{class.abstract} & If \tcode{T} is a non-union class type, \tcode{T} shall be a complete type. \\ \rowsep -\indexlibraryglobal{is_final}% \tcode{template}\br - \tcode{struct is_final;} & + \tcode{struct \libglobal{is_final};} & \tcode{T} is a class type marked with the \grammarterm{class-virt-specifier} \tcode{final}\iref{class.pre}. \begin{tailnote} @@ -876,9 +872,8 @@ & If \tcode{T} is a class type, \tcode{T} shall be a complete type. \\ \rowsep -\indexlibraryglobal{is_aggregate}% \tcode{template}\br - \tcode{struct is_aggregate;} & + \tcode{struct \libglobal{is_aggregate};} & \tcode{T} is an aggregate type\iref{dcl.init.aggr} & \tcode{T} shall be an array type, a complete type, or \cv~\keyword{void}. \\ \rowsep @@ -889,16 +884,14 @@ \tcode{T(-1) < T(0)}; otherwise, \tcode{false} & \\ \rowsep -\indexlibraryglobal{is_unsigned}% \tcode{template}\br - \tcode{struct is_unsigned;} & + \tcode{struct \libglobal{is_unsigned};} & If \tcode{is_arithmetic_v} is \tcode{true}, the same result as \tcode{T(0) < T(-1)}; otherwise, \tcode{false} & \\ \rowsep -\indexlibraryglobal{is_bounded_array}% \tcode{template}\br - \tcode{struct is_bounded_array;} & + \tcode{struct \libglobal{is_bounded_array};} & \tcode{T} is an array type of known bound\iref{dcl.array} & \\ \rowsep @@ -1392,7 +1385,7 @@ \end{libreqtab2a} \pnum -Each of these templates shall be a \oldconcept{UnaryTypeTrait}\iref{meta.rqmts} with a +Each of these templates shall be a \oldconceptref{UnaryTypeTrait}\iref{meta.rqmts} with a base characteristic of \tcode{integral_constant}. \pnum @@ -1428,7 +1421,7 @@ \pnum Each of these templates shall be a -\oldconcept{BinaryTypeTrait}\iref{meta.rqmts} +\oldconceptref{BinaryTypeTrait}\iref{meta.rqmts} with a base characteristic of \tcode{true_type} if the corresponding condition is true, otherwise \tcode{false_type}. @@ -1442,7 +1435,7 @@ \lhdr{Template} & \chdr{Condition} & \rhdr{Comments} \\ \capsep \endhead \tcode{template}\br - \tcode{struct is_same;} & + \tcode{struct \libglobal{is_same};} & \tcode{T} and \tcode{U} name the same type with the same cv-qualifications & \\ \rowsep \indexlibraryglobal{is_base_of}% @@ -1622,7 +1615,7 @@ \pnum Each of the templates in \ref{meta.trans} shall be a -\oldconcept{TransformationTrait}\iref{meta.rqmts}. +\oldconceptref{TransformationTrait}\iref{meta.rqmts}. \rSec3[meta.trans.cv]{Const-volatile modifications} @@ -1903,16 +1896,16 @@ \tcode{template\br struct \libglobal{remove_cvref};} & The member typedef \tcode{type} denotes - \tcode{remove_cv_t>}. + \tcode{\libglobalref{remove_cv_t}<\libglobalref{remove_reference_t}>}. \\ \rowsep \tcode{template\br struct \libglobal{decay};} & - Let \tcode{U} be \tcode{remove_reference_t}. If \tcode{is_array_v} is + Let \tcode{U} be \tcode{\libglobalref{remove_reference_t}}. If \tcode{\libglobalref{is_array_v}} is \tcode{true}, the member typedef \tcode{type} denotes - \tcode{remove_extent_t*}. If \tcode{is_function_v} is \tcode{true}, - the member typedef \tcode{type} denotes \tcode{add_pointer_t}. Otherwise - the member typedef \tcode{type} denotes \tcode{remove_cv_t}. + \tcode{\libglobalref{remove_extent_t}*}. If \tcode{\libglobalref{is_function_v}} is \tcode{true}, + the member typedef \tcode{type} denotes \tcode{\libglobalref{add_pointer_t}}. Otherwise + the member typedef \tcode{type} denotes \tcode{\libglobalref{remove_cv_t}}. \begin{tailnote} This behavior is similar to the lvalue-to-rvalue\iref{conv.lval}, array-to-pointer\iref{conv.array}, and function-to-pointer\iref{conv.func} @@ -1992,7 +1985,7 @@ \tcode{template} \tcode{struct \libglobal{unwrap_reference};} & If \tcode{T} is - a specialization \tcode{reference_wrapper} for some type \tcode{X}, + a specialization \tcode{\libglobalref{reference_wrapper}} for some type \tcode{X}, the member typedef \tcode{type} of \tcode{unwrap_reference} denotes \tcode{X\&}, otherwise \tcode{type} denotes \tcode{T}. \\ \rowsep @@ -2000,7 +1993,7 @@ \tcode{template} \tcode{\libglobal{unwrap_ref_decay};} & The member typedef \tcode{type} of \tcode{unwrap_ref_decay} - denotes the type \tcode{unwrap_reference_t>}.\\ + denotes the type \tcode{\libglobalref{unwrap_reference_t}<\libglobalref{decay_t}>}.\\ \end{libreqtab2a} \pnum @@ -2018,7 +2011,7 @@ Let: \begin{itemize} \item \tcode{\placeholdernc{CREF}(A)} be - \tcode{add_lvalue_reference_t{}>}, + \tcode{\libglobalref{add_lvalue_reference_t}{}>}, \item \tcode{\placeholdernc{XREF}(A)} denote a unary alias template \tcode{T} such that \tcode{T} denotes the same type as \tcode{U} with the addition of \tcode{A}'s cv and reference qualifiers, for a non-reference cv-unqualified @@ -2043,15 +2036,15 @@ \placeholdernc{COPYCV}(\brk{}Y, X) \&)} if that type exists and is a reference type. \item Otherwise, let \tcode{C} be - \tcode{remove_reference_t<\placeholdernc{COMMON-REF}(X\&, Y\&)>\&\&}. + \tcode{\libglobalref{remove_reference_t}<\placeholdernc{COMMON-REF}(X\&, Y\&)>\&\&}. If \tcode{A} and \tcode{B} are both rvalue reference types, \tcode{C} is well-formed, and - \tcode{is_convertible_v \&\& is_convertible_v} is \tcode{true}, + \tcode{\libglobalref{is_convertible_v} \&\& \libglobalref{is_convertible_v}} is \tcode{true}, then \tcode{\placeholdernc{COMMON-REF}(A, B)} is \tcode{C}. \item Otherwise, let \tcode{D} be \tcode{\placeholdernc{COMMON-REF}(const X\&, Y\&)}. If \tcode{A} is an rvalue reference and \tcode{B} is an lvalue reference and \tcode{D} is - well-formed and \tcode{is_convertible_v} is + well-formed and \tcode{\libglobalref{is_convertible_v}} is \tcode{true}, then \tcode{\placeholdernc{COMMON-REF}(A, B)} is \tcode{D}. \item Otherwise, if \tcode{A} is an lvalue reference and \tcode{B} is an rvalue reference, then \tcode{\placeholdernc{COMMON-REF}(A, B)} is @@ -2350,7 +2343,7 @@ The class template \tcode{negation} forms the logical negation of its template type argument. The type \tcode{negation} -is a \oldconcept{UnaryTypeTrait} with a base characteristic of \tcode{bool_constant}. +is a \oldconceptref{UnaryTypeTrait} with a base characteristic of \tcode{bool_constant}. \end{itemdescr} \rSec2[meta.member]{Member relationships} diff --git a/source/numerics.tex b/source/numerics.tex index d088b19b01..dabc36db40 100644 --- a/source/numerics.tex +++ b/source/numerics.tex @@ -41,10 +41,10 @@ A \Cpp{} program shall instantiate these components only with a numeric type. A \defnadj{numeric}{type} is a cv-unqualified object type \tcode{T} that meets the -\oldconcept{DefaultConstructible}, -\oldconcept{CopyConstructible}, -\oldconcept{CopyAssignable}, and -\oldconcept{Destructible} +\oldconceptref{DefaultConstructible}, +\oldconceptref{CopyConstructible}, +\oldconceptref{CopyAssignable}, and +\oldconceptref{Destructible} requirements\iref{utility.arg.requirements}. \begin{footnote} In other words, value types. @@ -2078,8 +2078,8 @@ \pnum \tcode{E} shall meet the -\oldconcept{CopyConstructible} (\tref{cpp17.copyconstructible}) -and \oldconcept{CopyAssignable} (\tref{cpp17.copyassignable}) requirements. +\oldconceptref{CopyConstructible} (\tref{cpp17.copyconstructible}) +and \oldconceptref{CopyAssignable} (\tref{cpp17.copyassignable}) requirements. These operations shall each be of complexity no worse than \bigoh{\text{size of state}}. @@ -2449,8 +2449,8 @@ \pnum \tcode{D} shall meet the -\oldconcept{CopyConstructible} (\tref{cpp17.copyconstructible}) -and \oldconcept{CopyAssignable} (\tref{cpp17.copyassignable}) requirements. +\oldconceptref{CopyConstructible} (\tref{cpp17.copyconstructible}) +and \oldconceptref{CopyAssignable} (\tref{cpp17.copyassignable}) requirements. \pnum The sequence of numbers @@ -2481,10 +2481,10 @@ \pnum \tcode{P} shall meet the -\oldconcept{CopyConstructible} (\tref{cpp17.copyconstructible}), -\oldconcept{CopyAssignable} (\tref{cpp17.copyassignable}), +\oldconceptref{CopyConstructible} (\tref{cpp17.copyconstructible}), +\oldconceptref{CopyAssignable} (\tref{cpp17.copyassignable}), and -\oldconcept{Equality\-Comp\-arable} (\tref{cpp17.equalitycomparable}) requirements. +\oldconceptref{EqualityComparable} (\tref{cpp17.equalitycomparable}) requirements. \pnum For each of the constructors of \tcode{D} @@ -4158,7 +4158,7 @@ \pnum \expects \tcode{InputIterator} meets the - \oldconcept{InputIterator} requirements\iref{input.iterators}. + \oldconceptref{InputIterator} requirements\iref{input.iterators}. \pnum \effects @@ -4185,7 +4185,7 @@ \pnum \expects \tcode{RandomAccessIterator} meets the - \oldconcept{RandomAccessIterator} requirements\iref{random.access.iterators} + \oldconceptref{RandomAccessIterator} requirements\iref{random.access.iterators} and the requirements of a mutable iterator. \pnum @@ -4298,7 +4298,7 @@ \pnum \expects \tcode{OutputIterator} meets the - \oldconcept{OutputIterator} requirements\iref{output.iterators}. + \oldconceptref{OutputIterator} requirements\iref{output.iterators}. \pnum \effects @@ -6291,7 +6291,7 @@ \pnum \expects \tcode{InputIterator} meets the - \oldconcept{InputIterator} requirements\iref{input.iterators}. + \oldconceptref{InputIterator} requirements\iref{input.iterators}. If \tcode{firstW == lastW}, let $n = 1$ and $w_0 = 1$. Otherwise, @@ -6489,7 +6489,7 @@ \expects \tcode{InputIteratorB} and \tcode{InputIteratorW} each meet the - \oldconcept{InputIterator} requirements\iref{input.iterators}. + \oldconceptref{InputIterator} requirements\iref{input.iterators}. If \tcode{firstB == lastB} or \tcode{++firstB == lastB}, let $n = 1$, @@ -6724,7 +6724,7 @@ \expects \tcode{InputIteratorB} and \tcode{InputIteratorW} each meet the - \oldconcept{InputIterator} requirements\iref{input.iterators}. + \oldconceptref{InputIterator} requirements\iref{input.iterators}. If \tcode{firstB == lastB} or \tcode{++firstB == lastB}, let $n = 1$, @@ -9070,12 +9070,12 @@ \pnum In the \tcode{begin} and \tcode{end} function templates that follow, \unspec{1} is a type that meets the requirements of a mutable -\oldconcept{RandomAccessIterator}\iref{random.access.iterators} +\oldconceptref{RandomAccessIterator}\iref{random.access.iterators} and models \libconcept{contiguous_iterator}\iref{iterator.concept.contiguous}, whose \tcode{value_type} is the template parameter \tcode{T} and whose \tcode{reference} type is \tcode{T\&}. \unspec{2} is a type that meets the requirements of a constant -\oldconcept{RandomAccessIterator} +\oldconceptref{RandomAccessIterator} and models \libconcept{contiguous_iterator}, whose \tcode{value_type} is the template parameter \tcode{T} and whose \tcode{reference} type is \tcode{const T\&}. diff --git a/source/strings.tex b/source/strings.tex index 593a1bd284..6fbe952af4 100644 --- a/source/strings.tex +++ b/source/strings.tex @@ -238,10 +238,10 @@ \pnum \expects \tcode{state_type} meets the -\oldconcept{Destructible} (\tref{cpp17.destructible}), -\oldconcept{CopyAssignable} (\tref{cpp17.copyassignable}), -\oldconcept{CopyConstructible} (\tref{cpp17.copyconstructible}), and -\oldconcept{DefaultConstructible} (\tref{cpp17.defaultconstructible}) requirements. +\oldconceptref{Destructible} (\tref{cpp17.destructible}), +\oldconceptref{CopyAssignable} (\tref{cpp17.copyassignable}), +\oldconceptref{CopyConstructible} (\tref{cpp17.copyconstructible}), and +\oldconceptref{DefaultConstructible} (\tref{cpp17.defaultconstructible}) requirements. \end{itemdescr} \rSec2[char.traits.specializations]{\tcode{char_traits} specializations} @@ -926,7 +926,7 @@ \pnum A type that meets the requirements of a constant -\oldconcept{RandomAccessIterator}\iref{random.access.iterators}, +\oldconceptref{RandomAccessIterator}\iref{random.access.iterators}, models \libconcept{contiguous_iterator}\iref{iterator.concept.contiguous}, and meets the constexpr iterator requirements\iref{iterator.requirements.general}, whose \tcode{value_type} is the template parameter \tcode{charT}. diff --git a/source/support.tex b/source/support.tex index c3f1c85ab9..14cf018bae 100644 --- a/source/support.tex +++ b/source/support.tex @@ -3569,11 +3569,11 @@ \pnum The type \tcode{source_location} meets the -\oldconcept{DefaultConstructible}, -\oldconcept{CopyConstructible}, -\oldconcept{Copy\-Assignable}, -\oldconcept{Swappable}, and -\oldconcept{Destructible} +\oldconceptref{DefaultConstructible}, +\oldconceptref{CopyConstructible}, +\oldconceptref{CopyAssignable}, +\oldconceptref{Swappable}, and +\oldconceptref{Destructible} requirements\iref{utility.arg.requirements,swappable.requirements}. All of the following conditions are \tcode{true}: \begin{itemize} @@ -4033,7 +4033,7 @@ \pnum \tcode{exception_ptr} meets the requirements of -\oldconcept{NullablePointer} (\tref{cpp17.nullablepointer}). +\oldconceptref{NullablePointer} (\tref{cpp17.nullablepointer}). \pnum Two non-null values of type \tcode{exception_ptr} are equivalent and compare equal if and @@ -4233,7 +4233,7 @@ \pnum \expects -\tcode{U} meets the \oldconcept{CopyConstructible} requirements. +\tcode{U} meets the \oldconceptref{CopyConstructible} requirements. \pnum \throws diff --git a/source/threads.tex b/source/threads.tex index fb6b0ee7a3..548bc46102 100644 --- a/source/threads.tex +++ b/source/threads.tex @@ -41,7 +41,7 @@ \tcode{false} otherwise. If a template parameter is named \tcode{Clock}, the corresponding template argument shall be a type \tcode{C} -that meets the \oldconcept{Clock} requirements\iref{time.clock.req}; +that meets the \oldconceptref{Clock} requirements\iref{time.clock.req}; the program is ill-formed if \tcode{is_clock_v} is \tcode{false}. \rSec2[thread.req.exception]{Exceptions} @@ -156,7 +156,7 @@ \pnum Implementation-provided clocks that are used for these functions meet the -\oldconcept{TrivialClock} requirements\iref{time.clock.req}. +\oldconceptref{TrivialClock} requirements\iref{time.clock.req}. \pnum A function that takes an argument which specifies a timeout will throw if, @@ -195,10 +195,10 @@ \tcode{lock_guard}\iref{thread.lock.guard}, \tcode{lock}, \tcode{try_lock}\iref{thread.lock.algorithm}, and \tcode{condition_variable_any}\iref{thread.condition.condvarany} all operate on user-supplied -lockable objects. The \oldconcept{BasicLockable} requirements, the \oldconcept{Lockable} requirements, -the \oldconcept{TimedLockable} requirements, -the \oldconcept{SharedLockable} requirements, and -the \oldconcept{SharedTimedLock\-able} requirements +lockable objects. The \oldconceptref{BasicLockable} requirements, the \oldconceptref{Lockable} requirements, +the \oldconceptref{TimedLockable} requirements, +the \oldconceptref{SharedLockable} requirements, and +the \oldconceptref{SharedTimedLockable} requirements list the requirements imposed by these library types in order to acquire or release ownership of a \tcode{lock} by a given execution agent. \begin{note} @@ -266,7 +266,7 @@ \rSec3[thread.req.lockable.req]{\oldconcept{Lockable} requirements} \pnum -A type \tcode{L} meets the \defnoldconcept{Lockable} requirements if it meets the \oldconcept{BasicLockable} +A type \tcode{L} meets the \defnoldconcept{Lockable} requirements if it meets the \oldconceptref{BasicLockable} requirements and the following expressions are well-formed and have the specified semantics (\tcode{m} denotes a value of type \tcode{L}). @@ -291,7 +291,7 @@ \rSec3[thread.req.lockable.timed]{\oldconcept{TimedLockable} requirements} \pnum -A type \tcode{L} meets the \defnoldconcept{TimedLockable} requirements if it meets the \oldconcept{Lockable} +A type \tcode{L} meets the \defnoldconcept{TimedLockable} requirements if it meets the \oldconceptref{Lockable} requirements and the following expressions are well-formed and have the specified semantics (\tcode{m} denotes a value of type \tcode{L}, \tcode{rel_time} denotes a value of an instantiation of \link{\tcode{duration}}{time.duration}, and \tcode{abs_time} denotes a value @@ -397,7 +397,7 @@ \pnum A type \tcode{L} meets the \defnoldconcept{SharedTimedLockable} requirements if -it meets the \oldconcept{SharedLockable} requirements, and +it meets the \oldconceptref{SharedLockable} requirements, and the following expressions are well-formed, have type \tcode{bool}, and have the specified semantics (\tcode{m} denotes a value of type \tcode{L}, @@ -4171,7 +4171,7 @@ \indexlibraryglobal{atomic}% \pnum The template argument for \tcode{T} shall meet the -\oldconcept{CopyConstructible} and \oldconcept{CopyAssignable} requirements. +\oldconceptref{CopyConstructible} and \oldconceptref{CopyAssignable} requirements. The program is ill-formed if any of \begin{itemize} \item \tcode{is_trivially_copyable_v}, @@ -6650,11 +6650,11 @@ They meet the requirements set out in \ref{thread.mutex.requirements.mutex}. In this description, \tcode{m} denotes an object of a mutex type. \begin{note} -The mutex types meet the \oldconcept{Lockable} requirements\iref{thread.req.lockable.req}. +The mutex types meet the \oldconceptref{Lockable} requirements\iref{thread.req.lockable.req}. \end{note} \pnum -The mutex types meet \oldconcept{DefaultConstructible} and \oldconcept{Destructible}. +The mutex types meet \oldconceptref{DefaultConstructible} and \oldconceptref{Destructible}. If initialization of an object of a mutex type fails, an exception of type \tcode{system_error} is thrown. The mutex types are neither copyable nor movable. @@ -6923,7 +6923,7 @@ object of an instantiation of \link{\tcode{time_point}}{time.point}. \begin{note} -The timed mutex types meet the \oldconcept{TimedLockable} +The timed mutex types meet the \oldconceptref{TimedLockable} requirements\iref{thread.req.lockable.timed}. \end{note} @@ -7135,7 +7135,7 @@ meet the requirements set out below. In this description, \tcode{m} denotes an object of a shared mutex type. \begin{note} -The shared mutex types meet the \oldconcept{SharedLockable} +The shared mutex types meet the \oldconceptref{SharedLockable} requirements\iref{thread.req.lockable.shared}. \end{note} @@ -7312,7 +7312,7 @@ \tcode{abs_time} denotes an object of an instantiation of \link{\tcode{time_point}}{time.point}. \begin{note} -The shared timed mutex types meet the \oldconcept{SharedTimedLockable} +The shared timed mutex types meet the \oldconceptref{SharedTimedLockable} requirements\iref{thread.req.lockable.shared.timed}. \end{note} @@ -7522,7 +7522,7 @@ object throughout the \tcode{lock_guard} object's \deflink{lifetime}{basic.life}. The behavior of a program is undefined if the lockable object referenced by \tcode{pm} does not exist for the entire lifetime of the \tcode{lock_guard} -object. The supplied \tcode{Mutex} type shall meet the \oldconcept{BasicLockable} +object. The supplied \tcode{Mutex} type shall meet the \oldconceptref{BasicLockable} requirements\iref{thread.req.lockable.basic}. \indexlibraryctor{lock_guard}% @@ -7601,12 +7601,12 @@ If \tcode{sizeof...(MutexTypes)} is one, let \tcode{Mutex} denote the sole type constituting the pack \tcode{MutexTypes}. \tcode{Mutex} -shall meet the \oldconcept{BasicLockable} requirements\iref{thread.req.lockable.basic}. +shall meet the \oldconceptref{BasicLockable} requirements\iref{thread.req.lockable.basic}. The member \grammarterm{typedef-name} \tcode{mutex_type} denotes the same type as \tcode{Mutex}. \item Otherwise, all types in the template parameter pack \tcode{MutexTypes} -shall meet the \oldconcept{Lockable} requirements\iref{thread.req.lockable.req} +shall meet the \oldconceptref{Lockable} requirements\iref{thread.req.lockable.req} and there is no member \tcode{mutex_type}. \end{itemize} @@ -7721,17 +7721,17 @@ \tcode{pm} is not null and the lockable object pointed to by \tcode{pm} does not exist for the entire remaining lifetime\iref{basic.life} of the \tcode{unique_lock} object. The supplied -\tcode{Mutex} type shall meet the \oldconcept{BasicLockable} +\tcode{Mutex} type shall meet the \oldconceptref{BasicLockable} requirements\iref{thread.req.lockable.basic}. \pnum \begin{note} -\tcode{unique_lock} meets the \oldconcept{BasicLockable} requirements. If \tcode{Mutex} -meets the \oldconcept{Lockable} requirements\iref{thread.req.lockable.req}, -\tcode{unique_lock} also meets the \oldconcept{Lockable} requirements; +\tcode{unique_lock} meets the \oldconceptref{BasicLockable} requirements. If \tcode{Mutex} +meets the \oldconceptref{Lockable} requirements\iref{thread.req.lockable.req}, +\tcode{unique_lock} also meets the \oldconceptref{Lockable} requirements; if \tcode{Mutex} -meets the \oldconcept{TimedLockable} requirements\iref{thread.req.lockable.timed}, -\tcode{unique_lock} also meets the \oldconcept{TimedLockable} requirements. +meets the \oldconceptref{TimedLockable} requirements\iref{thread.req.lockable.timed}, +\tcode{unique_lock} also meets the \oldconceptref{TimedLockable} requirements. \end{note} \rSec4[thread.lock.unique.cons]{Constructors, destructor, and assignment} @@ -7781,7 +7781,7 @@ \begin{itemdescr} \pnum \expects -The supplied \tcode{Mutex} type meets the \oldconcept{Lockable} +The supplied \tcode{Mutex} type meets the \oldconceptref{Lockable} requirements\iref{thread.req.lockable.req}. \pnum @@ -7823,7 +7823,7 @@ \pnum \expects The supplied \tcode{Mutex} type meets the -\oldconcept{TimedLockable} requirements\iref{thread.req.lockable.timed}. +\oldconceptref{TimedLockable} requirements\iref{thread.req.lockable.timed}. \pnum \effects @@ -7845,7 +7845,7 @@ \begin{itemdescr} \pnum \expects -The supplied \tcode{Mutex} type meets the \oldconcept{TimedLockable} requirements\iref{thread.req.lockable.timed}. +The supplied \tcode{Mutex} type meets the \oldconceptref{TimedLockable} requirements\iref{thread.req.lockable.timed}. \pnum \effects @@ -7941,7 +7941,7 @@ \begin{itemdescr} \pnum \expects -The supplied \tcode{Mutex} meets the \oldconcept{Lockable} +The supplied \tcode{Mutex} meets the \oldconceptref{Lockable} requirements\iref{thread.req.lockable.req}. \pnum @@ -7980,7 +7980,7 @@ \begin{itemdescr} \pnum \expects -The supplied \tcode{Mutex} type meets the \oldconcept{TimedLockable} +The supplied \tcode{Mutex} type meets the \oldconceptref{TimedLockable} requirements\iref{thread.req.lockable.timed}. \pnum @@ -8019,7 +8019,7 @@ \begin{itemdescr} \pnum \expects -The supplied \tcode{Mutex} type meets the \oldconcept{TimedLockable} requirements\iref{thread.req.lockable.timed}. +The supplied \tcode{Mutex} type meets the \oldconceptref{TimedLockable} requirements\iref{thread.req.lockable.timed}. \pnum \effects @@ -8212,16 +8212,16 @@ is undefined if the contained pointer \tcode{pm} is not null and the lockable object pointed to by \tcode{pm} does not exist for the entire remaining lifetime\iref{basic.life} of the \tcode{shared_lock} object. The supplied -\tcode{Mutex} type shall meet the \oldconcept{SharedLockable} +\tcode{Mutex} type shall meet the \oldconceptref{SharedLockable} requirements\iref{thread.req.lockable.shared}. \pnum \begin{note} -\tcode{shared_lock} meets the \oldconcept{Lockable} +\tcode{shared_lock} meets the \oldconceptref{Lockable} requirements\iref{thread.req.lockable.req}. -If \tcode{Mutex} meets the \oldconcept{Shared\-TimedLockable} +If \tcode{Mutex} meets the \oldconceptref{SharedTimedLockable} requirements\iref{thread.req.lockable.shared.timed}, -\tcode{shared_lock} also meets the \oldconcept{TimedLockable} +\tcode{shared_lock} also meets the \oldconceptref{TimedLockable} requirements\iref{thread.req.lockable.timed}. \end{note} @@ -8306,7 +8306,7 @@ \begin{itemdescr} \pnum \expects -\tcode{Mutex} meets the \oldconcept{SharedTimedLockable} +\tcode{Mutex} meets the \oldconceptref{SharedTimedLockable} requirements\iref{thread.req.lockable.shared.timed}. \pnum @@ -8330,7 +8330,7 @@ \begin{itemdescr} \pnum \expects -\tcode{Mutex} meets the \oldconcept{SharedTimedLockable} +\tcode{Mutex} meets the \oldconceptref{SharedTimedLockable} requirements\iref{thread.req.lockable.shared.timed}. \pnum @@ -8457,7 +8457,7 @@ \begin{itemdescr} \pnum \expects -\tcode{Mutex} meets the \oldconcept{SharedTimedLockable} +\tcode{Mutex} meets the \oldconceptref{SharedTimedLockable} requirements\iref{thread.req.lockable.shared.timed}. \pnum @@ -8497,7 +8497,7 @@ \begin{itemdescr} \pnum \expects -\tcode{Mutex} meets the \oldconcept{SharedTimedLockable} +\tcode{Mutex} meets the \oldconceptref{SharedTimedLockable} requirements\iref{thread.req.lockable.shared.timed}. \pnum @@ -8636,7 +8636,7 @@ \begin{itemdescr} \pnum \expects -Each template parameter type meets the \oldconcept{Lockable} requirements. +Each template parameter type meets the \oldconceptref{Lockable} requirements. \begin{note} The \tcode{unique_lock} class template meets these requirements when suitably instantiated. @@ -8665,7 +8665,7 @@ \begin{itemdescr} \pnum \expects -Each template parameter type meets the \oldconcept{Lockable} requirements. +Each template parameter type meets the \oldconceptref{Lockable} requirements. \begin{note} The \tcode{unique_lock} class template meets these requirements when suitably instantiated. @@ -9331,7 +9331,7 @@ \pnum In \ref{thread.condition.condvarany}, template arguments for template parameters named \tcode{Lock} -shall meet the \oldconcept{Basic\-Lockable} +shall meet the \oldconceptref{BasicLockable} requirements\iref{thread.req.lockable.basic}. \begin{note} All of the standard @@ -10269,24 +10269,24 @@ \pnum \tcode{CompletionFunction} shall meet the -\oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}) and -\oldconcept{Destructible} (\tref{cpp17.destructible}) requirements. +\oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) and +\oldconceptref{Destructible} (\tref{cpp17.destructible}) requirements. \tcode{is_nothrow_invocable_v} shall be \tcode{true}. \pnum The default value of the \tcode{CompletionFunction} template parameter is an unspecified type, such that, in addition to satisfying the requirements of \tcode{CompletionFunction}, -it meets the \oldconcept{DefaultConstructible} +it meets the \oldconceptref{DefaultConstructible} requirements (\tref{cpp17.defaultconstructible}) and \tcode{completion()} has no effects. \pnum \tcode{barrier::arrival_token} is an unspecified type, such that it meets the -\oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}), -\oldconcept{MoveAssignable} (\tref{cpp17.moveassignable}), and -\oldconcept{Destructible} (\tref{cpp17.destructible}) requirements. +\oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}), +\oldconceptref{MoveAssignable} (\tref{cpp17.moveassignable}), and +\oldconceptref{Destructible} (\tref{cpp17.destructible}) requirements. \indexlibrarymember{max}{barrier}% \begin{itemdecl} @@ -10787,7 +10787,7 @@ \pnum For the primary template, \tcode{R} shall be an object type that -meets the \oldconcept{Destructible} requirements. +meets the \oldconceptref{Destructible} requirements. \pnum The implementation provides the template \tcode{promise} and two specializations, @@ -10812,7 +10812,7 @@ \pnum \expects \tcode{Alloc} meets -the \oldconcept{Allocator} requirements\iref{allocator.requirements.general}. +the \oldconceptref{Allocator} requirements\iref{allocator.requirements.general}. \end{itemdescr} \indexlibraryctor{promise}% @@ -11133,7 +11133,7 @@ \pnum For the primary template, \tcode{R} shall be an object type that -meets the \oldconcept{Destructible} requirements. +meets the \oldconceptref{Destructible} requirements. \pnum The implementation provides the template \tcode{future} and two specializations, @@ -11439,7 +11439,7 @@ \pnum For the primary template, \tcode{R} shall be an object type that -meets the \oldconcept{Destructible} requirements. +meets the \oldconceptref{Destructible} requirements. \pnum The implementation provides the template \tcode{shared_future} and two @@ -12347,7 +12347,7 @@ \pnum \tcode{D} shall meet the requirements for -\oldconcept{DefaultConstructible} and \oldconcept{MoveAssignable}. +\oldconceptref{DefaultConstructible} and \oldconceptref{MoveAssignable}. \pnum If \tcode{D} is trivially copyable, @@ -12405,7 +12405,7 @@ \pnum This class meets the requirements of -\oldconcept{Lockable}\iref{thread.req.lockable.req} and +\oldconceptref{Lockable}\iref{thread.req.lockable.req} and provides regions of RCU protection. \begin{example} \begin{codeblock} @@ -12553,8 +12553,8 @@ \pnum \expects -\tcode{D} meets the \oldconcept{MoveConstructible} and -\oldconcept{Destructible} requirements. +\tcode{D} meets the \oldconceptref{MoveConstructible} and +\oldconceptref{Destructible} requirements. \pnum \effects @@ -12746,7 +12746,7 @@ \pnum \tcode{D} shall meet the requirements for -\oldconcept{DefaultConstructible} and \oldconcept{MoveAssignable}. +\oldconceptref{DefaultConstructible} and \oldconceptref{MoveAssignable}. \pnum \tcode{T} may be an incomplete type. diff --git a/source/time.tex b/source/time.tex index 2ab4949b1f..12dce5fb64 100644 --- a/source/time.tex +++ b/source/time.tex @@ -1039,13 +1039,13 @@ A type \tcode{TC} meets the \defnoldconcept{TrivialClock} requirements if \begin{itemize} \item -\tcode{TC} meets the \oldconcept{Clock} requirements, +\tcode{TC} meets the \oldconceptref{Clock} requirements, \item the types \tcode{TC::rep}, \tcode{TC::duration}, and \tcode{TC::time_point} -meet the \oldconcept{EqualityComparable} (\tref{cpp17.equalitycomparable}) and -\oldconcept{LessThanComparable} (\tref{cpp17.lessthancomparable}) -and \oldconcept{Swappable}\iref{swappable.requirements} +meet the \oldconceptref{EqualityComparable} (\tref{cpp17.equalitycomparable}) and +\oldconceptref{LessThanComparable} (\tref{cpp17.lessthancomparable}) +and \oldconceptref{Swappable}\iref{swappable.requirements} requirements and the requirements of numeric types\iref{numeric.requirements}, \begin{note} @@ -1203,15 +1203,15 @@ \end{itemdecl} \pnum -\tcode{is_clock} is a \oldconcept{UnaryTypeTrait}\iref{meta.rqmts} +\tcode{is_clock} is a \oldconceptref{UnaryTypeTrait}\iref{meta.rqmts} with a base characteristic of \tcode{true_type} -if \tcode{T} meets the \oldconcept{Clock} requirements\iref{time.clock.req}, +if \tcode{T} meets the \oldconceptref{Clock} requirements\iref{time.clock.req}, otherwise \tcode{false_type}. For the purposes of the specification of this trait, the extent to which an implementation determines -that a type cannot meet the \oldconcept{Clock} requirements is unspecified, +that a type cannot meet the \oldconceptref{Clock} requirements is unspecified, except that as a minimum -a type \tcode{T} shall not qualify as a \oldconcept{Clock} +a type \tcode{T} shall not qualify as a \oldconceptref{Clock} unless it meets all of the following conditions: \begin{itemize} \item the \grammarterm{qualified-id}s @@ -2632,7 +2632,7 @@ \pnum The types defined in \ref{time.clock} meet the -\oldconcept{TrivialClock} +\oldconceptref{TrivialClock} requirements\iref{time.clock.req} unless otherwise specified. @@ -2850,7 +2850,7 @@ \end{example} \pnum -\tcode{utc_clock} is not a \oldconcept{TrivialClock} +\tcode{utc_clock} is not a \oldconceptref{TrivialClock} unless the implementation can guarantee that \tcode{utc_clock::now()} does not propagate an exception. \begin{note} @@ -3069,7 +3069,7 @@ (22s plus the initial 10s offset). \pnum -\tcode{tai_clock} is not a \oldconcept{TrivialClock} +\tcode{tai_clock} is not a \oldconceptref{TrivialClock} unless the implementation can guarantee that \tcode{tai_clock::now()} does not propagate an exception. \begin{note} @@ -3231,7 +3231,7 @@ and the additional 9 leap seconds inserted between 1970 and 1980. \pnum -\tcode{gps_clock} is not a \oldconcept{TrivialClock} +\tcode{gps_clock} is not a \oldconceptref{TrivialClock} unless the implementation can guarantee that \tcode{gps_clock::now()} does not propagate an exception. \begin{note} @@ -3368,7 +3368,7 @@ \pnum \tcode{file_clock} is an alias for a type -meeting the \oldconcept{TrivialClock} requirements\iref{time.clock.req}, and +meeting the \oldconceptref{TrivialClock} requirements\iref{time.clock.req}, and using a signed arithmetic type for \tcode{file_clock::rep}. \tcode{file_clock} is used to create the \tcode{time_point} system used for \tcode{file_time_type}\iref{filesystems}. @@ -3971,8 +3971,8 @@ but may hold non-negative values outside this range. It can be constructed with any \tcode{unsigned} value, which will be subsequently truncated to fit into \tcode{day}'s unspecified internal storage. -\tcode{day} meets the \oldconcept{EqualityComparable} (\tref{cpp17.equalitycomparable}) -and \oldconcept{LessThanComparable} (\tref{cpp17.lessthancomparable}) requirements, +\tcode{day} meets the \oldconceptref{EqualityComparable} (\tref{cpp17.equalitycomparable}) +and \oldconceptref{LessThanComparable} (\tref{cpp17.lessthancomparable}) requirements, and participates in basic arithmetic with \tcode{days} objects, which represent a difference between two \tcode{day} objects. @@ -4264,8 +4264,8 @@ but may hold non-negative values outside this range. It can be constructed with any \tcode{unsigned} value, which will be subsequently truncated to fit into \tcode{month}'s unspecified internal storage. -\tcode{month} meets the \oldconcept{EqualityComparable} (\tref{cpp17.equalitycomparable}) -and \oldconcept{LessThanComparable} (\tref{cpp17.lessthancomparable}) requirements, +\tcode{month} meets the \oldconceptref{EqualityComparable} (\tref{cpp17.equalitycomparable}) +and \oldconceptref{LessThanComparable} (\tref{cpp17.lessthancomparable}) requirements, and participates in basic arithmetic with \tcode{months} objects, which represent a difference between two \tcode{month} objects. @@ -4574,8 +4574,8 @@ It can represent values in the range \crange{min()}{max()}. It can be constructed with any \tcode{int} value, which will be subsequently truncated to fit into \tcode{year}'s unspecified internal storage. -\tcode{year} meets the \oldconcept{EqualityComparable} (\tref{cpp17.equalitycomparable}) -and \oldconcept{LessThanComparable} (\tref{cpp17.lessthancomparable}) requirements, +\tcode{year} meets the \oldconceptref{EqualityComparable} (\tref{cpp17.equalitycomparable}) +and \oldconceptref{LessThanComparable} (\tref{cpp17.lessthancomparable}) requirements, and participates in basic arithmetic with \tcode{years} objects, which represent a difference between two \tcode{year} objects. @@ -4929,10 +4929,10 @@ it may hold non-negative values outside this range. It can be constructed with any \tcode{unsigned} value, which will be subsequently truncated to fit into \tcode{weekday}'s unspecified internal storage. -\tcode{weekday} meets the \oldconcept{EqualityComparable} (\tref{cpp17.equalitycomparable}) requirements. +\tcode{weekday} meets the \oldconceptref{EqualityComparable} (\tref{cpp17.equalitycomparable}) requirements. \begin{note} \tcode{weekday} is not -\oldconcept{LessThanComparable} +\oldconceptref{LessThanComparable} because there is no universal consensus on which day is the first day of the week. \tcode{weekday}'s arithmetic operations treat the days of the week as a circular range, with no beginning and no end. @@ -5512,8 +5512,8 @@ \pnum \tcode{month_day} represents a specific day of a specific month, but with an unspecified year. -\tcode{month_day} meets the \oldconcept{EqualityComparable} (\tref{cpp17.equalitycomparable}) -and \oldconcept{LessThanComparable} (\tref{cpp17.lessthancomparable}) requirements. +\tcode{month_day} meets the \oldconceptref{EqualityComparable} (\tref{cpp17.equalitycomparable}) +and \oldconceptref{LessThanComparable} (\tref{cpp17.lessthancomparable}) requirements. \pnum \tcode{month_day} is a trivially copyable and standard-layout class type. @@ -6013,8 +6013,8 @@ \tcode{year_month} represents a specific month of a specific year, but with an unspecified day. \tcode{year_month} is a field-based time point with a resolution of \tcode{months}. -\tcode{year_month} meets the \oldconcept{EqualityComparable} (\tref{cpp17.equalitycomparable}) -and \oldconcept{LessThanComparable} (\tref{cpp17.lessthancomparable}) requirements. +\tcode{year_month} meets the \oldconceptref{EqualityComparable} (\tref{cpp17.equalitycomparable}) +and \oldconceptref{LessThanComparable} (\tref{cpp17.lessthancomparable}) requirements. \pnum \tcode{year_month} is a trivially copyable and standard-layout class type. @@ -6369,8 +6369,8 @@ For the latter, there is a conversion to \tcode{sys_days}, which efficiently supports \tcode{days}-oriented arithmetic. \end{note} -\tcode{year_month_day} meets the \oldconcept{EqualityComparable} (\tref{cpp17.equalitycomparable}) -and \oldconcept{LessThanComparable} (\tref{cpp17.lessthancomparable}) requirements. +\tcode{year_month_day} meets the \oldconceptref{EqualityComparable} (\tref{cpp17.equalitycomparable}) +and \oldconceptref{LessThanComparable} (\tref{cpp17.lessthancomparable}) requirements. \pnum \tcode{year_month_day} is a trivially copyable and standard-layout class type. @@ -6830,8 +6830,8 @@ For the latter, there is a conversion to \tcode{sys_days}, which efficiently supports \tcode{days}-oriented arithmetic. \end{note} -\tcode{year_month_day_last} meets the \oldconcept{EqualityComparable} (\tref{cpp17.equalitycomparable}) -and \oldconcept{LessThanComparable} (\tref{cpp17.lessthancomparable}) requirements. +\tcode{year_month_day_last} meets the \oldconceptref{EqualityComparable} (\tref{cpp17.equalitycomparable}) +and \oldconceptref{LessThanComparable} (\tref{cpp17.lessthancomparable}) requirements. \pnum \tcode{year_month_day_last} is a trivially copyable and standard-layout class type. @@ -7201,7 +7201,7 @@ For the latter, there is a conversion to \tcode{sys_days}, which efficiently supports \tcode{days}-oriented arithmetic. \end{note} -\tcode{year_month_weekday} meets the \oldconcept{EqualityComparable} (\tref{cpp17.equalitycomparable}) requirements. +\tcode{year_month_weekday} meets the \oldconceptref{EqualityComparable} (\tref{cpp17.equalitycomparable}) requirements. \pnum \tcode{year_month_weekday} is a trivially copyable and standard-layout class type. @@ -7594,7 +7594,7 @@ For the latter, there is a conversion to \tcode{sys_days}, which efficiently supports \tcode{days}-oriented arithmetic. \end{note} -\tcode{year_month_weekday_last} meets the \oldconcept{EqualityComparable} (\tref{cpp17.equalitycomparable}) requirements. +\tcode{year_month_weekday_last} meets the \oldconceptref{EqualityComparable} (\tref{cpp17.equalitycomparable}) requirements. \pnum \tcode{year_month_weekday_last} is a trivially copyable and standard-layout class type. @@ -8844,7 +8844,7 @@ \pnum \tcode{tzdb_list::const_iterator} is a constant iterator -which meets the \oldconcept{ForwardIterator} requirements +which meets the \oldconceptref{ForwardIterator} requirements and has a value type of \tcode{tzdb}. \indexlibrarymember{front}{tzdb_list}% @@ -11554,7 +11554,7 @@ The specializations are enabled\iref{unord.hash}. \begin{note} All the \tcode{hash} specializations listed above meet the -\oldconcept{Hash} requirements, even when called on objects \tcode{k} +\oldconceptref{Hash} requirements, even when called on objects \tcode{k} of type \tcode{Key} such that \tcode{k.ok()} is \tcode{false}. \end{note} \end{itemdescr} diff --git a/source/utilities.tex b/source/utilities.tex index f94c312e91..d76ba58dcf 100644 --- a/source/utilities.tex +++ b/source/utilities.tex @@ -242,9 +242,9 @@ Type \tcode{T} meets the -\oldconcept{MoveConstructible} (\tref{cpp17.moveconstructible}) +\oldconceptref{MoveConstructible} (\tref{cpp17.moveconstructible}) and -\oldconcept{MoveAssignable} (\tref{cpp17.moveassignable}) +\oldconceptref{MoveAssignable} (\tref{cpp17.moveassignable}) requirements. \pnum @@ -2111,7 +2111,7 @@ \pnum \expects \tcode{Alloc} meets -the \oldconcept{Allocator} requirements\iref{allocator.requirements.general}. +the \oldconceptref{Allocator} requirements\iref{allocator.requirements.general}. \pnum \effects @@ -2741,7 +2741,7 @@ \pnum Except where specified otherwise, all specializations of \tcode{tuple_size} meet the -\oldconcept{UnaryTypeTrait} requirements\iref{meta.rqmts} with a +\oldconceptref{UnaryTypeTrait} requirements\iref{meta.rqmts} with a base characteristic of \tcode{integral_constant} for some \tcode{N}. \end{itemdescr} @@ -2782,7 +2782,7 @@ Let \tcode{TS} denote \tcode{tuple_size} of the cv-unqualified type \tcode{T}. If the expression \tcode{TS::value} is well-formed when treated as an \deflink{unevaluated operand}{expr.context}, then -each specialization of the template meets the \oldconcept{Unary\-Type\-Trait} requirements\iref{meta.rqmts} +each specialization of the template meets the \oldconceptref{UnaryTypeTrait} requirements\iref{meta.rqmts} with a base characteristic of \begin{codeblock} integral_constant @@ -2819,7 +2819,7 @@ \begin{itemdescr} \pnum Let \tcode{TE} denote \tcode{tuple_element_t} of the cv-unqualified type \tcode{T}. Then -each specialization of the template meets the \oldconcept{TransformationTrait} requirements\iref{meta.rqmts} +each specialization of the template meets the \oldconceptref{TransformationTrait} requirements\iref{meta.rqmts} with a member typedef \tcode{type} that names the type \tcode{add_const_t}. \pnum @@ -3098,7 +3098,7 @@ \pnum \expects \tcode{Alloc} meets -the \oldconcept{Allocator} requirements\iref{allocator.requirements.general}. +the \oldconceptref{Allocator} requirements\iref{allocator.requirements.general}. \pnum \begin{note} @@ -3351,7 +3351,7 @@ \pnum \tcode{T} shall be a type other than \cv{} \tcode{in_place_t} or \cv{} \tcode{nullopt_t} -that meets the \oldconcept{Destructible} requirements (\tref{cpp17.destructible}). +that meets the \oldconceptref{Destructible} requirements (\tref{cpp17.destructible}). \rSec3[optional.ctor]{Constructors} @@ -3971,7 +3971,7 @@ \pnum \expects -\tcode{T} meets the \oldconcept{Swappable} requirements\iref{swappable.requirements}. +\tcode{T} meets the \oldconceptref{Swappable} requirements\iref{swappable.requirements}. \pnum \effects @@ -4028,7 +4028,7 @@ \pnum These types model \libconcept{contiguous_iterator}\iref{iterator.concept.contiguous}, -meet the \oldconcept{RandomAccessIterator} requirements\iref{random.access.iterators}, and +meet the \oldconceptref{RandomAccessIterator} requirements\iref{random.access.iterators}, and meet the requirements for constexpr iterators\iref{iterator.requirements.general}, with value type \tcode{remove_cv_t}. The reference type is \tcode{T\&} for \tcode{iterator} and @@ -4468,7 +4468,7 @@ The expression \tcode{*x == *y} is well-formed and its result is convertible to \tcode{bool}. \begin{note} -\tcode{T} need not be \oldconcept{EqualityComparable}. +\tcode{T} need not be \oldconceptref{EqualityComparable}. \end{note} \pnum @@ -4659,7 +4659,7 @@ The expression \tcode{*x == v} is well-formed and its result is convertible to \tcode{bool}. \begin{note} -\tcode{T} need not be \oldconcept{EqualityComparable}. +\tcode{T} need not be \oldconceptref{EqualityComparable}. \end{note} \pnum @@ -5146,7 +5146,7 @@ \pnum All types in \tcode{Types} shall meet -the \oldconcept{Destructible} requirements (\tref{cpp17.destructible}). +the \oldconceptref{Destructible} requirements (\tref{cpp17.destructible}). \pnum A program that instantiates the definition of \tcode{variant} with @@ -5826,7 +5826,7 @@ \pnum \expects -Each $\tcode{T}_i$ meets the \oldconcept{Swappable} requirements\iref{swappable.requirements}. +Each $\tcode{T}_i$ meets the \oldconceptref{Swappable} requirements\iref{swappable.requirements}. \pnum \effects @@ -5871,7 +5871,7 @@ \begin{itemdescr} \pnum All specializations of \tcode{variant_size} meet the -\oldconcept{UnaryTypeTrait} requirements\iref{meta.rqmts} +\oldconceptref{UnaryTypeTrait} requirements\iref{meta.rqmts} with a base characteristic of \tcode{integral_constant} for some \tcode{N}. \end{itemdescr} @@ -5884,7 +5884,7 @@ \pnum Let \tcode{VS} denote \tcode{variant_size} of the cv-unqualified type \tcode{T}. Then each specialization of the template meets the -\oldconcept{UnaryTypeTrait} requirements\iref{meta.rqmts} with a +\oldconceptref{UnaryTypeTrait} requirements\iref{meta.rqmts} with a base characteristic of \tcode{integral_constant}. \end{itemdescr} @@ -5904,7 +5904,7 @@ \pnum Let \tcode{VA} denote \tcode{variant_alternative} of the cv-unqualified type \tcode{T}. Then each specialization of the template -meets the \oldconcept{TransformationTrait} requirements\iref{meta.rqmts} with a +meets the \oldconceptref{TransformationTrait} requirements\iref{meta.rqmts} with a member typedef \tcode{type} that names the type \tcode{add_const_t}. \end{itemdescr} @@ -6630,7 +6630,7 @@ \pnum \expects -\tcode{VT} meets the \oldconcept{CopyConstructible} requirements. +\tcode{VT} meets the \oldconceptref{CopyConstructible} requirements. \pnum \effects @@ -6658,7 +6658,7 @@ \pnum \expects -\tcode{VT} meets the \oldconcept{CopyConstructible} requirements. +\tcode{VT} meets the \oldconceptref{CopyConstructible} requirements. \pnum \effects @@ -6691,7 +6691,7 @@ \pnum \expects -\tcode{VT} meets the \oldconcept{CopyConstructible} requirements. +\tcode{VT} meets the \oldconceptref{CopyConstructible} requirements. \pnum \effects @@ -6776,7 +6776,7 @@ \pnum \expects -\tcode{VT} meets the \oldconcept{CopyConstructible} requirements. +\tcode{VT} meets the \oldconceptref{CopyConstructible} requirements. \pnum \effects @@ -6811,7 +6811,7 @@ \pnum \expects -\tcode{VT} meets the \oldconcept{CopyConstructible} requirements. +\tcode{VT} meets the \oldconceptref{CopyConstructible} requirements. \pnum \effects @@ -6855,7 +6855,7 @@ \pnum \expects -\tcode{VT} meets the \oldconcept{CopyConstructible} requirements. +\tcode{VT} meets the \oldconceptref{CopyConstructible} requirements. \pnum \effects @@ -7557,9 +7557,9 @@ \pnum When \tcode{T} is not \cv{} \tcode{void}, it shall meet -the \oldconcept{Destructible} requirements (\tref{cpp17.destructible}). +the \oldconceptref{Destructible} requirements (\tref{cpp17.destructible}). \tcode{E} shall meet -the \oldconcept{Destructible} requirements. +the \oldconceptref{Destructible} requirements. \rSec3[expected.object.cons]{Constructors} @@ -8797,7 +8797,7 @@ The expression \tcode{*x == v} is well-formed and its result is convertible to \tcode{bool}. \begin{note} -\tcode{T} need not be \oldconcept{EqualityComparable}. +\tcode{T} need not be \oldconceptref{EqualityComparable}. \end{note} \pnum @@ -8934,7 +8934,7 @@ \pnum \tcode{E} shall meet the requirements of -\oldconcept{Destructible} (\tref{cpp17.destructible}). +\oldconceptref{Destructible} (\tref{cpp17.destructible}). \rSec3[expected.void.cons]{Constructors} @@ -10961,8 +10961,8 @@ \indextext{call wrapper}% \indextext{call wrapper!simple}% \indextext{call wrapper!forwarding}% -Every call wrapper\iref{func.def} meets the \oldconcept{MoveConstructible} -and \oldconcept{Destructible} requirements. +Every call wrapper\iref{func.def} meets the \oldconceptref{MoveConstructible} +and \oldconceptref{Destructible} requirements. An \defn{argument forwarding call wrapper} is a call wrapper that can be called with an arbitrary argument list and delivers the arguments to the target object as references. @@ -11002,7 +11002,7 @@ \pnum \label{term.simple.call.wrapper}% A \defn{simple call wrapper} is a perfect forwarding call wrapper that meets -the \oldconcept{CopyConstructible} and \oldconcept{CopyAssignable} requirements +the \oldconceptref{CopyConstructible} and \oldconceptref{CopyAssignable} requirements and whose copy constructor, move constructor, and assignment operators are constexpr functions that do not throw exceptions. @@ -11105,7 +11105,7 @@ \end{codeblock} \pnum -\tcode{reference_wrapper} is a \oldconcept{CopyConstructible} and \oldconcept{CopyAssignable} wrapper +\tcode{reference_wrapper} is a \oldconceptref{CopyConstructible} and \oldconceptref{CopyAssignable} wrapper around a reference to an object or function of type \tcode{T}. \pnum @@ -12559,7 +12559,7 @@ \pnum \expects -\tcode{FD} meets the \oldconcept{MoveConstructible} requirements. +\tcode{FD} meets the \oldconceptref{MoveConstructible} requirements. \pnum \returns @@ -12645,10 +12645,10 @@ \pnum \expects -\tcode{FD} meets the \oldconcept{MoveConstructible} requirements. +\tcode{FD} meets the \oldconceptref{MoveConstructible} requirements. For each $\tcode{T}_i$ in \tcode{BoundArgs}, if $\tcode{T}_i$ is an object type, -$\tcode{T}_i$ meets the \oldconcept{MoveConstructible} requirements. +$\tcode{T}_i$ meets the \oldconceptref{MoveConstructible} requirements. \pnum \returns @@ -12714,7 +12714,7 @@ \pnum \expects For each $\tcode{T}_i$ in \tcode{BoundArgs}, -$\tcode{T}_i$ meets the \oldconcept{MoveConstructible} requirements. +$\tcode{T}_i$ meets the \oldconceptref{MoveConstructible} requirements. \pnum \returns @@ -12759,7 +12759,7 @@ \pnum Specializations of the \tcode{is_bind_expression} template shall meet -the \oldconcept{UnaryTypeTrait} requirements\iref{meta.rqmts}. The implementation +the \oldconceptref{UnaryTypeTrait} requirements\iref{meta.rqmts}. The implementation provides a definition that has a base characteristic of \tcode{true_type} if \tcode{T} is a type returned from \tcode{bind}, otherwise it has a base characteristic of \tcode{false_type}. @@ -12795,7 +12795,7 @@ \pnum Specializations of the \tcode{is_placeholder} template shall meet -the \oldconcept{UnaryTypeTrait} requirements\iref{meta.rqmts}. The implementation +the \oldconceptref{UnaryTypeTrait} requirements\iref{meta.rqmts}. The implementation provides a definition that has the base characteristic of \tcode{integral_constant} if \tcode{T} is the type of \tcode{std::placeholders::_\placeholder{J}}, otherwise it has a @@ -12845,7 +12845,7 @@ \pnum \expects \tcode{FD} and each $\tcode{TD}_i$ meet -the \oldconcept{MoveConstructible} and \oldconcept{Destructible} requirements. +the \oldconceptref{MoveConstructible} and \oldconceptref{Destructible} requirements. \tcode{\placeholdernc{INVOKE}(fd, $\tcode{w}_1$, $\tcode{w}_2$, $\dotsc$, $\tcode{w}_N$)}\iref{func.require} is a valid expression for some values $\tcode{w}_1$, $\tcode{w}_2$, $\dotsc{}$, $\tcode{w}_N$, where @@ -12881,8 +12881,8 @@ \pnum \begin{note} If all of \tcode{FD} and $\tcode{TD}_i$ meet -the requirements of \oldconcept{CopyConstructible}, then -the return type meets the requirements of \oldconcept{CopyConstructible}. +the requirements of \oldconceptref{CopyConstructible}, then +the return type meets the requirements of \oldconceptref{CopyConstructible}. \end{note} \end{itemdescr} @@ -12953,13 +12953,13 @@ \impldef{number of placeholders for bind expressions}. \pnum -All placeholder types meet the \oldconcept{DefaultConstructible} and -\oldconcept{CopyConstructible} requirements, and +All placeholder types meet the \oldconceptref{DefaultConstructible} and +\oldconceptref{CopyConstructible} requirements, and their default constructors and copy/move constructors are constexpr functions that do not throw exceptions. It is \impldef{assignability of placeholder objects} whether -placeholder types meet the \oldconcept{CopyAssignable} requirements, +placeholder types meet the \oldconceptref{CopyAssignable} requirements, but if so, their copy assignment operators are constexpr functions that do not throw exceptions. @@ -13240,7 +13240,7 @@ \pnum \expects -\tcode{FD} meets the \oldconcept{CopyConstructible} requirements. +\tcode{FD} meets the \oldconceptref{CopyConstructible} requirements. \pnum \ensures @@ -13666,9 +13666,9 @@ \pnum \expects -\tcode{VT} meets the \oldconcept{Destructible} requirements, and +\tcode{VT} meets the \oldconceptref{Destructible} requirements, and if \tcode{is_move_constructible_v} is \tcode{true}, -\tcode{VT} meets the \oldconcept{MoveConstructible} requirements. +\tcode{VT} meets the \oldconceptref{MoveConstructible} requirements. \pnum \ensures @@ -13718,9 +13718,9 @@ \pnum \expects -\tcode{VT} meets the \oldconcept{Destructible} requirements, and +\tcode{VT} meets the \oldconceptref{Destructible} requirements, and if \tcode{is_move_constructible_v} is \tcode{true}, -\tcode{VT} meets the \oldconcept{MoveConstructible} requirements. +\tcode{VT} meets the \oldconceptref{MoveConstructible} requirements. \pnum \ensures @@ -13760,9 +13760,9 @@ \pnum \expects -\tcode{VT} meets the \oldconcept{Destructible} requirements, and +\tcode{VT} meets the \oldconceptref{Destructible} requirements, and if \tcode{is_move_constructible_v} is \tcode{true}, -\tcode{VT} meets the \oldconcept{MoveConstructible} requirements. +\tcode{VT} meets the \oldconceptref{MoveConstructible} requirements. \pnum \ensures @@ -14084,8 +14084,8 @@ \pnum \expects -\tcode{VT} meets the \oldconcept{Destructible} and -\oldconcept{CopyConstructible} requirements. +\tcode{VT} meets the \oldconceptref{Destructible} and +\oldconceptref{CopyConstructible} requirements. \pnum \ensures @@ -14140,8 +14140,8 @@ \pnum \expects -\tcode{VT} meets the \oldconcept{Destructible} and -\oldconcept{CopyConstructible} requirements. +\tcode{VT} meets the \oldconceptref{Destructible} and +\oldconceptref{CopyConstructible} requirements. \pnum \ensures @@ -14186,8 +14186,8 @@ \pnum \expects -\tcode{VT} meets the \oldconcept{Destructible} and -\oldconcept{CopyConstructible} requirements. +\tcode{VT} meets the \oldconceptref{Destructible} and +\oldconceptref{CopyConstructible} requirements. \pnum \ensures @@ -14702,7 +14702,7 @@ \pnum Each specialization of a class template specified in \ref{func.search} -shall meet the \oldconcept{CopyConst\-ruct\-ible} and \oldconcept{CopyAssignable} requirements. +shall meet the \oldconceptref{CopyConstructible} and \oldconceptref{CopyAssignable} requirements. Template parameters named \begin{itemize} \item \tcode{ForwardIterator}, @@ -14716,7 +14716,7 @@ of templates specified in \ref{func.search} shall meet the same requirements and semantics as specified in \ref{algorithms.general}. -Template parameters named \tcode{Hash} shall meet the \oldconcept{Hash} +Template parameters named \tcode{Hash} shall meet the \oldconceptref{Hash} requirements (\tref{cpp17.hash}). \pnum @@ -14825,9 +14825,9 @@ \pnum \expects The value type of \tcode{RandomAccessIterator1} meets -the \oldconcept{DefaultConstructible}, -\oldconcept{CopyConstructible}, and -\oldconcept{CopyAssignable} requirements. +the \oldconceptref{DefaultConstructible}, +\oldconceptref{CopyConstructible}, and +\oldconceptref{CopyAssignable} requirements. \pnum Let \tcode{V} be \tcode{iterator_traits::val\-ue_type}. @@ -14926,8 +14926,8 @@ \begin{itemdescr} \pnum \expects -The value type of \tcode{RandomAccessIterator1} meets the \oldconcept{DefaultConstructible}, -\oldconcept{Copy\-Constructible}, and \oldconcept{CopyAssignable} requirements. +The value type of \tcode{RandomAccessIterator1} meets the \oldconceptref{DefaultConstructible}, +\oldconceptref{CopyConstructible}, and \oldconceptref{CopyAssignable} requirements. \pnum Let \tcode{V} be \tcode{iterator_traits::val\-ue_type}. @@ -15000,7 +15000,7 @@ Each specialization of \tcode{hash} is either enabled or disabled, as described below. \begin{note} -Enabled specializations meet the \oldconcept{Hash} requirements, and +Enabled specializations meet the \oldconceptref{Hash} requirements, and disabled specializations do not. \end{note} Each header that declares the template \tcode{hash} @@ -15027,17 +15027,17 @@ are not function object types\iref{function.objects}. \begin{note} This means that the specialization of \tcode{hash} exists, but -any attempts to use it as a \oldconcept{Hash} will be ill-formed. +any attempts to use it as a \oldconceptref{Hash} will be ill-formed. \end{note} \pnum An enabled specialization \tcode{hash} will: \begin{itemize} -\item meet the \oldconcept{Hash} requirements (\tref{cpp17.hash}), +\item meet the \oldconceptref{Hash} requirements (\tref{cpp17.hash}), with \tcode{Key} as the function -call argument type, the \oldconcept{Default\-Constructible} requirements (\tref{cpp17.defaultconstructible}), -the \oldconcept{CopyAssignable} requirements (\tref{cpp17.copyassignable}), -the \oldconcept{Swappable} requirements\iref{swappable.requirements}, +call argument type, the \oldconceptref{DefaultConstructible} requirements (\tref{cpp17.defaultconstructible}), +the \oldconceptref{CopyAssignable} requirements (\tref{cpp17.copyassignable}), +the \oldconceptref{Swappable} requirements\iref{swappable.requirements}, \item meet the requirement that if \tcode{k1 == k2} is \tcode{true}, \tcode{h(k1) == h(k2)} is also \tcode{true}, where \tcode{h} is an object of type \tcode{hash} and \tcode{k1} and \tcode{k2} are objects of type \tcode{Key};