cgal/STL_Extension/doc_tex/STL_Extension_ref/Default.tex

48 lines
1.8 KiB
TeX

\begin{ccRefClass}{Default}
\ccDefinition
\ccRefName\ is a tag class. It can be used to state that one wants
to use the default argument of a template parameter of a class template.
This can be useful in several cases: (a) when one needs a non-default value for
another template parameter coming next (since \CC\ only supports defaults at
the end of lists), (b) when the default is actually a complex expression, e.g.
refering to previous template parameters (in this case, it shortens compiler
error messages and mangled symbol names), (c) when defining the default
involves circular dependencies of type instantiations (there, it breaks the
cycle in a nice way).
Using the mechanism is easy~: just plug \ccRefName\ as template argument
in the place where you would like to use the default. You should refer
to the documentation of the template class you are using in order to know
whether this functionality is offered.
Also beware that the type of the instantiated template class will not be the
same when instantiating it using \ccRefName\ instead of the type of the default
argument, even though their interfaces will otherwise be the same. This may
have consequences in some cases.
\ccIsModel
\ccc{DefaultConstructible, CopyConstructible}
\begin{ccAdvanced}
In order to help the template class writer, \ccRefName\ provides a convenient
way to extract the desired type for a template parameter which may be defaulted
using \ccRefName. It is enough to fetch the type as
\ccc{Default::Get<Parameter, Type>::type}, as in the example program below.
\ccTypes
\ccNestedType{template <typename Parameter, typename Type> struct Get;}
{A nested template providing a typedef \ccc{type} which equals \ccc{Type} if
\ccc{Parameter} is \ccRefName, and \ccc{Parameter} otherwise.}
\end{ccAdvanced}
\ccHeading{Example}
\ccIncludeExampleCode{STL_Extension/Default.cpp}
\end{ccRefClass}