X-Git-Url: https://www.ginac.de/ginac.git//ginac.git?p=ginac.git;a=blobdiff_plain;f=ginac%2Frelational.h;h=1ca6089336c71d3517df247c2b1a678c37172767;hp=317b1d23523f041e067013ab984bf9af7f3bc56d;hb=857ca8ca24fbfe26d4c0c624aa6c3f2296c419f8;hpb=487e5659efe401683eee0381b0d23f967ffffc3c diff --git a/ginac/relational.h b/ginac/relational.h index 317b1d23..1ca60893 100644 --- a/ginac/relational.h +++ b/ginac/relational.h @@ -3,7 +3,7 @@ * Interface to relations between expressions. */ /* - * GiNaC Copyright (C) 1999 Johannes Gutenberg University Mainz, Germany + * GiNaC Copyright (C) 1999-2000 Johannes Gutenberg University Mainz, Germany * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -23,13 +23,18 @@ #ifndef __GINAC_RELATIONAL_H__ #define __GINAC_RELATIONAL_H__ -#include -#include +#include "basic.h" +#include "ex.h" + +#ifndef NO_NAMESPACE_GINAC +namespace GiNaC { +#endif // ndef NO_NAMESPACE_GINAC /** This class holds a relation consisting of two expressions and a logical * relation between them. */ class relational : public basic { + GINAC_DECLARE_REGISTERED_CLASS(relational, basic) // types public: @@ -47,35 +52,37 @@ public: public: relational(); ~relational(); - relational(relational const & other); - relational const & operator=(relational const & other); + relational(const relational & other); + const relational & operator=(const relational & other); protected: - void copy(relational const & other); + void copy(const relational & other); void destroy(bool call_parent); // other constructors public: - relational(ex const & lhs, ex const & rhs, operators oper=equal); + relational(const ex & lhs, const ex & rhs, operators oper=equal); // functions overriding virtual functions from bases classes public: basic * duplicate() const; - void printraw(ostream & os) const; void print(ostream & os, unsigned upper_precedence=0) const; + void printraw(ostream & os) const; void printcsrc(ostream & os, unsigned type, unsigned upper_precedence=0) const; bool info(unsigned inf) const; - int nops() const; - ex & let_op(int const i); + unsigned nops() const; + ex & let_op(int i); ex eval(int level=0) const; ex evalf(int level=0) const; - ex simplify_ncmul(exvector const & v) const; + ex simplify_ncmul(const exvector & v) const; protected: - int compare_same_type(basic const & other) const; + int compare_same_type(const basic & other) const; unsigned return_type(void) const; unsigned return_type_tinfo(void) const; // new virtual functions which can be overridden by derived classes - // none +public: + virtual ex lhs(void) const; + virtual ex rhs(void) const; // non-virtual functions in this class public: @@ -93,10 +100,16 @@ protected: // global constants extern const relational some_relational; -extern type_info const & typeid_relational; +extern const type_info & typeid_relational; -#define ex_to_relational(X) static_cast(*(X).bp) - -#endif // ndef __GINAC_RELATIONAL_H__ +// utility functions +inline const relational &ex_to_relational(const ex &e) +{ + return static_cast(*e.bp); +} +#ifndef NO_NAMESPACE_GINAC +} // namespace GiNaC +#endif // ndef NO_NAMESPACE_GINAC +#endif // ndef __GINAC_RELATIONAL_H__