#include "ex.h"
#include "numeric.h"
+#include "print.h"
namespace GiNaC {
~expair() { }
expair(const expair & other) : rest(other.rest), coeff(other.coeff)
{
- GINAC_ASSERT(is_ex_exactly_of_type(coeff,numeric));
+ GINAC_ASSERT(is_exactly_a<numeric>(coeff));
}
const expair & operator=(const expair & other)
{
/** Construct an expair from two ex. */
expair(const ex & r, const ex & c) : rest(r), coeff(c)
{
- GINAC_ASSERT(is_ex_exactly_of_type(coeff,numeric));
+ GINAC_ASSERT(is_exactly_a<numeric>(coeff));
}
/** Member-wise check for canonical ordering equality. */
return coeff.compare(other.coeff);
}
- /** Output to ostream in ugly raw format. */
- void printraw(std::ostream & os) const
+ void print(std::ostream & os) const
{
- os << "expair(";
- rest.printraw(os);
- os << ",";
- coeff.printraw(os);
- os << ")";
+ os << "expair:";
+ print_tree c(os);
+ rest.print(c, c.delta_indent);
+ coeff.print(c, c.delta_indent);
}
/** True if this is of the form (numeric,ex(1)). */
bool is_canonical_numeric(void) const
{
- GINAC_ASSERT(is_ex_exactly_of_type(coeff,numeric));
+ GINAC_ASSERT(is_exactly_a<numeric>(coeff));
return (is_ex_exactly_of_type(rest,numeric) &&
(coeff.is_equal(1)));
}