#include <vector>
#include <list>
+
+// CINT needs <algorithm> to work properly with <vector> and <list>
+//#include <algorithm>
+
#include <ginac/expair.h>
+#ifndef NO_GINAC_NAMESPACE
+namespace GiNaC {
+#endif // ndef NO_GINAC_NAMESPACE
+
//#define EXPAIRSEQ_USE_HASHTAB
typedef vector<expair> epvector;
inline void iter_swap(epvector::iterator it1, epvector::iterator it2)
{
- debugmsg("iter_swap epvector",LOGLEVEL_NONMEMBER_FUNCTION);
(*it1).rest.swap((*it2).rest);
(*it1).coeff.swap((*it2).coeff);
}
, hashtabsize(0)
#endif // def EXPAIRSEQ_USE_HASHTAB
{
- debugmsg("expairseq default constructor",LOGLEVEL_CONSTRUCT);
}
~expairseq()
{
- debugmsg("expairseq destructor",LOGLEVEL_DESTRUCT);
destroy(0);
}
expairseq(expairseq const & other);
extern const expairseq some_expairseq;
extern type_info const & typeid_expairseq;
-#define ex_to_expairseq(X) static_cast<expairseq const &>(*(X).bp)
+// utility functions
+inline const expairseq &ex_to_expairseq(const ex &e)
+{
+ return static_cast<const expairseq &>(*e.bp);
+}
+
+#ifndef NO_GINAC_NAMESPACE
+} // namespace GiNaC
+#endif // ndef NO_GINAC_NAMESPACE
#endif // ndef __GINAC_EXPAIRSEQ_H__