mirror of
https://github.com/boostorg/proto.git
synced 2026-01-30 08:02:38 +00:00
265 lines
11 KiB
XML
265 lines
11 KiB
XML
<?xml version="1.0" encoding="utf-8"?>
|
|
<header name="boost/proto/generate.hpp">
|
|
<para>Contains definition of <computeroutput><classname alt="boost::proto::generator">proto::generator<></classname></computeroutput>
|
|
class template and friends that end users can use to generate domain-specific expression wrappers.</para>
|
|
<namespace name="boost">
|
|
<namespace name="proto">
|
|
<!-- proto::default_generator -->
|
|
<struct name="default_generator">
|
|
<purpose>A simple generator that passes an expression through unchanged.</purpose>
|
|
<description>
|
|
<para>
|
|
Generators are intended for use as the first template parameter to the
|
|
<computeroutput><classname alt="proto::domain">proto::domain<></classname></computeroutput>
|
|
class template and control if and how expressions within that domain are to be customized.
|
|
The <computeroutput>proto::default_generator</computeroutput> makes no modifications to the
|
|
expressions passed to it.
|
|
</para>
|
|
</description>
|
|
<inherit>
|
|
<type>proto::callable</type>
|
|
</inherit>
|
|
<struct-specialization name="result">
|
|
<template>
|
|
<template-type-parameter name="This"/>
|
|
<template-type-parameter name="Expr"/>
|
|
</template>
|
|
<specialization>
|
|
<template-arg>This(Expr)</template-arg>
|
|
</specialization>
|
|
<typedef name="type">
|
|
<type>Expr</type>
|
|
</typedef>
|
|
</struct-specialization>
|
|
<method-group name="public member functions">
|
|
<method name="operator()" cv="const">
|
|
<type>Expr</type>
|
|
<template>
|
|
<template-type-parameter name="Expr"/>
|
|
</template>
|
|
<parameter name="expr">
|
|
<paramtype>Expr const &</paramtype>
|
|
<description>
|
|
<para>A Proto expression</para>
|
|
</description>
|
|
</parameter>
|
|
<returns>
|
|
<para><computeroutput>expr</computeroutput></para>
|
|
</returns>
|
|
</method>
|
|
</method-group>
|
|
</struct>
|
|
|
|
<!-- proto::generator -->
|
|
<struct name="generator">
|
|
<template>
|
|
<template-nontype-parameter name="Extends">
|
|
<type>template< typename > class</type>
|
|
</template-nontype-parameter>
|
|
</template>
|
|
<purpose>A generator that wraps expressions passed to it in the specified extension wrapper.</purpose>
|
|
<description>
|
|
<para>
|
|
Generators are intended for use as the first template parameter to the
|
|
<computeroutput><classname alt="proto::domain">proto::domain<></classname></computeroutput>
|
|
class template and control if and how expressions within that domain are to be customized.
|
|
<computeroutput>proto::generator<></computeroutput> wraps each expression passed to it in
|
|
the <computeroutput>Extends<></computeroutput> wrapper.
|
|
</para>
|
|
</description>
|
|
<struct-specialization name="result">
|
|
<template>
|
|
<template-type-parameter name="This"/>
|
|
<template-type-parameter name="Expr"/>
|
|
</template>
|
|
<specialization>
|
|
<template-arg>This(Expr)</template-arg>
|
|
</specialization>
|
|
<typedef name="type">
|
|
<type>Extends< Expr ></type>
|
|
</typedef>
|
|
</struct-specialization>
|
|
<method-group name="public member functions">
|
|
<method name="operator()" cv="const">
|
|
<type>Extends< Expr ></type>
|
|
<template>
|
|
<template-type-parameter name="Expr"/>
|
|
</template>
|
|
<parameter name="expr">
|
|
<paramtype>Expr const &</paramtype>
|
|
<description>
|
|
<para>A Proto expression</para>
|
|
</description>
|
|
</parameter>
|
|
<returns>
|
|
<para><computeroutput>Extends<Expr>(expr)</computeroutput></para>
|
|
</returns>
|
|
</method>
|
|
</method-group>
|
|
</struct>
|
|
|
|
<!-- proto::pod_generator -->
|
|
<struct name="pod_generator">
|
|
<template>
|
|
<template-nontype-parameter name="Extends">
|
|
<type>template< typename > class</type>
|
|
</template-nontype-parameter>
|
|
</template>
|
|
<purpose>A generator that wraps expressions passed to it in the specified extension wrapper and uses aggregate initialization for the wrapper. </purpose>
|
|
<description>
|
|
<para>
|
|
Generators are intended for use as the first template parameter to the
|
|
<computeroutput><classname alt="proto::domain">proto::domain<></classname></computeroutput>
|
|
class template and control if and how expressions within that domain are to be customized.
|
|
<computeroutput>proto::pod_generator<></computeroutput> wraps each expression passed
|
|
to it in the <computeroutput>Extends<></computeroutput> wrapper, and uses aggregate
|
|
initialzation for the wrapped object.
|
|
</para>
|
|
</description>
|
|
<inherit>
|
|
<type><classname>proto::callable</classname></type>
|
|
</inherit>
|
|
<struct-specialization name="result">
|
|
<template>
|
|
<template-type-parameter name="This"/>
|
|
<template-type-parameter name="Expr"/>
|
|
</template>
|
|
<specialization>
|
|
<template-arg>This(Expr)</template-arg>
|
|
</specialization>
|
|
<typedef name="type">
|
|
<type>Extends< Expr ></type>
|
|
</typedef>
|
|
</struct-specialization>
|
|
<method-group name="public member functions">
|
|
<method name="operator()" cv="const">
|
|
<type>Extends< Expr ></type>
|
|
<template>
|
|
<template-type-parameter name="Expr"/>
|
|
</template>
|
|
<parameter name="expr">
|
|
<paramtype>Expr const &</paramtype>
|
|
<description>
|
|
<para>A Proto expression</para>
|
|
</description>
|
|
</parameter>
|
|
<returns>
|
|
<para>
|
|
<computeroutput>Extends<Expr> that = {expr}; return that;</computeroutput>
|
|
</para>
|
|
</returns>
|
|
</method>
|
|
</method-group>
|
|
</struct>
|
|
|
|
<!-- by_value_generator -->
|
|
<struct name="by_value_generator">
|
|
<purpose>A generator that replaces child nodes held by reference with ones held by value.
|
|
Use with <computeroutput><classname alt="proto::compose_generators">proto::compose_generators<></classname>
|
|
</computeroutput> to forward that result to another generator.
|
|
</purpose>
|
|
<description>
|
|
<para>
|
|
Generators are intended for use as the first template parameter to the
|
|
<computeroutput><classname alt="proto::domain">proto::domain<></classname></computeroutput>
|
|
class template and control if and how expressions within that domain are to be customized.
|
|
<computeroutput>proto::by_value_generator</computeroutput> ensures all child nodes are held
|
|
by value. This generator is typically composed with a second generator for further processing,
|
|
as <computeroutput><classname>proto::compose_generators</classname><proto::by_value_generator,
|
|
MyGenerator></computeroutput>.
|
|
</para>
|
|
</description>
|
|
<inherit>
|
|
<type><classname>proto::callable</classname></type>
|
|
</inherit>
|
|
<struct-specialization name="result">
|
|
<template>
|
|
<template-type-parameter name="This"/>
|
|
<template-type-parameter name="Expr"/>
|
|
</template>
|
|
<specialization>
|
|
<template-arg>This(Expr)</template-arg>
|
|
</specialization>
|
|
<typedef name="type">
|
|
<type><emphasis>unspecified</emphasis></type>
|
|
</typedef>
|
|
</struct-specialization>
|
|
<method-group name="public member functions">
|
|
<method name="operator()" cv="const">
|
|
<type><emphasis>unspecified</emphasis></type>
|
|
<template>
|
|
<template-type-parameter name="Expr"/>
|
|
</template>
|
|
<parameter name="expr">
|
|
<paramtype>Expr const &</paramtype>
|
|
<description>
|
|
<para>A Proto expression.</para>
|
|
</description>
|
|
</parameter>
|
|
<returns>
|
|
<para>Equivalent to <computeroutput><functionname>proto::deep_copy</functionname>(expr)</computeroutput></para>
|
|
</returns>
|
|
</method>
|
|
</method-group>
|
|
</struct>
|
|
|
|
<!-- proto::compose_generator -->
|
|
<struct name="compose_generators">
|
|
<template>
|
|
<template-type-parameter name="First"/>
|
|
<template-type-parameter name="Second"/>
|
|
</template>
|
|
<purpose>A composite generator that first applies one transform to an expression and then forwards
|
|
the result on to another generator for further transformation.</purpose>
|
|
<description>
|
|
<para>
|
|
Generators are intended for use as the first template parameter to the
|
|
<computeroutput><classname alt="proto::domain">proto::domain<></classname></computeroutput>
|
|
class template and control if and how expressions within that domain are to be customized.
|
|
<computeroutput>proto::compose_generators<></computeroutput> is a composite generator
|
|
that first applies one transform to an expression and then forwards the result on to another
|
|
generator for further transformation.
|
|
</para>
|
|
</description>
|
|
<inherit>
|
|
<type><classname>proto::callable</classname></type>
|
|
</inherit>
|
|
<struct-specialization name="result">
|
|
<template>
|
|
<template-type-parameter name="This"/>
|
|
<template-type-parameter name="Expr"/>
|
|
</template>
|
|
<specialization>
|
|
<template-arg>This(Expr)</template-arg>
|
|
</specialization>
|
|
<inherit>
|
|
<type>
|
|
boost::result_of<
|
|
Second(typename boost::result_of<First(Expr)>::type)
|
|
></type>
|
|
</inherit>
|
|
</struct-specialization>
|
|
<method-group name="public member functions">
|
|
<method name="operator()" cv="const">
|
|
<type>typename boost::result_of<
|
|
Second(typename boost::result_of<First(Expr)>::type)
|
|
>::type</type>
|
|
<template>
|
|
<template-type-parameter name="Expr"/>
|
|
</template>
|
|
<parameter name="expr">
|
|
<paramtype>Expr const &</paramtype>
|
|
<description>
|
|
<para>A Proto expression.</para>
|
|
</description>
|
|
</parameter>
|
|
<returns>
|
|
<para><computeroutput>Second()(First()(expr))</computeroutput></para>
|
|
</returns>
|
|
</method>
|
|
</method-group>
|
|
</struct>
|
|
</namespace>
|
|
</namespace>
|
|
</header>
|