5 #include <boost/range.hpp>  
   23       virtual ~exp() = 
default;
 
   79     template <
typename Context>
 
   81       : 
public std::enable_shared_from_this<node<Context>>
 
   88       using value_t = std::shared_ptr<const node_t>;
 
  100     template <
typename Context>
 
  102       : 
public node<Context>
 
  117     template <exp::type_t Type, 
typename Context>
 
  119       : 
public inner<Context>
 
  154       auto tail() const -> decltype(boost::make_iterator_range(*this, 1, 0));
 
  158       template <typename... Vs>
 
  160         : 
sub_{std::forward<Vs>(vs)...}
 
  169       values_t 
subs() 
const;
 
  181     template <
typename Context, 
bool Enable>
 
  183       : 
public inner<Context>
 
  186       static_assert(Context::is_lat,
 
  187                     "tuple: requires a tupleset labelset");
 
  193       template <
unsigned Tape>
 
  195         = std::shared_ptr<const rat::node<detail::project_context<Tape, context_t>>>;
 
  197       template <
typename Sequence>
 
  200       template <
size_t... I>
 
  203         using type = std::tuple<value_t_of<I>...>;
 
  208       template <
typename... Args>
 
  210         : 
sub_{std::forward<Args>(args)...}
 
  225     template <
typename Context>
 
  227       : 
public inner<Context>
 
  234     template <exp::type_t Type, 
typename Context>
 
  236       : 
public inner<Context>
 
  239       static_assert(
is_unary(Type), 
"invalid type");
 
  263     template <exp::type_t Type, 
typename Context>
 
  265       : 
public inner<Context>
 
  279       const weight_t& 
weight() 
const;
 
  280       void set_weight(weight_t w);
 
  285         , weight_(that.weight_)
 
  301     template <
typename Context>
 
  303       : 
public node<Context>
 
  310     template <exp::type_t Type, 
typename Context>
 
  312       : 
public leaf<Context>
 
  326     template <
typename Context>
 
  328       : 
public leaf<Context>
 
  341       const label_t& value() 
const;
 
constexpr bool is_constant(type_t t)
Whether is a constant (\z or \e). 
typename labelset_t_of< context_t >::indices_t indices_t
typename super_t::value_t value_t
typename detail::label_t_of_impl< base_t< ValueSet >>::type label_t_of
The root from which to derive the final node types. 
variadic(const variadic &that)
virtual type_t type() const 
The type of this node. 
typename super_t::value_t value_t
void visit(const tuple< context_t > &v)
The abstract parameterized, root for all rational expression types. 
typename values_t::const_reverse_iterator const_reverse_iterator
values_t subs() const 
Return a copy of children. 
type_t
The possible types of expressions. 
virtual type_t type() const 
The type of this node. 
virtual type_t type() const 
The type of this node. 
virtual void accept(typename super_t::const_visitor &v) const 
vcsn::rat::const_visitor< context_t > const_visitor
virtual type_t type() const 
The type of this node. 
std::vector< value_t > values_t
constexpr bool is_unary(type_t t)
Whether star, complement. 
std::shared_ptr< const detail::weight_base > weight
The abstract, non-parameterized, root for all rational expression node types. 
auto tail() const -> decltype(boost::make_iterator_range(*this, 1, 0))
The non-first items. 
rat::type_t type_t
The possible types of expressions. 
Implementation of nodes of tuple of rational expressions. 
typename super_t::values_t values_t
const_iterator end() const 
typename detail::labelset_t_of_impl< base_t< ValueSet >>::type labelset_t_of
const_reverse_iterator rbegin() const 
const_iterator begin() const 
std::tuple< value_t_of< I >...> type
virtual type_t type() const =0
The type of this node. 
const value_t back() const 
The last item of this variadic. 
label_t_of< Context > label_t
std::shared_ptr< const node_t > value_t
An expression usable with value semantics. 
constexpr bool is_variadic(type_t t)
Whether one of the variadic types. 
virtual type_t type() const 
The type of this node. 
bool is_unary() const 
Whether star, complement. 
const value_t head() const 
The first item of this variadic. 
std::shared_ptr< const rat::node< detail::project_context< Tape, context_t >>> value_t_of
Given a tape, its corresponding expression type. 
virtual void accept(const_visitor &v) const =0
const_reverse_iterator rend() const 
weight_node(const weight_node &that)
An inner node implementing a weight. 
const values_t sub() const 
const_reverse_iterator reverse_iterator
virtual type_t type() const 
The type of this node. 
weight_t_of< Context > weight_t
bool is_leaf() const 
Whether a leaf of the expression tree. 
typename values_t::const_iterator const_iterator
virtual void accept(typename super_t::const_visitor &v) const 
An inner node with multiple children. 
const value_t operator[](size_t n) const 
Access the n-th element. 
typename detail::weight_t_of_impl< base_t< ValueSet >>::type weight_t_of