/** @file indexed.h
*
- * Interface to GiNaC's index carrying objects.
- *
+ * Interface to GiNaC's index carrying objects. */
+
+/*
* GiNaC Copyright (C) 1999 Johannes Gutenberg University Mainz, Germany
*
* This program is free software; you can redistribute it and/or modify
#include <string>
#include <ginac/exprseq.h>
+#ifndef NO_GINAC_NAMESPACE
+namespace GiNaC {
+#endif // ndef NO_GINAC_NAMESPACE
+
/** Base class for non-commutative indexed objects */
class indexed : public exprseq
{
indexed(ex const & i1);
indexed(ex const & i1, ex const & i2);
indexed(ex const & i1, ex const & i2, ex const & i3);
+ indexed(ex const & i1, ex const & i2, ex const & i3, ex const & i4);
indexed(exvector const & iv);
indexed(exvector * iv);
extern const indexed some_indexed;
extern type_info const & typeid_indexed;
-// macros
+// utility functions
+inline const indexed &ex_to_indexed(const ex &e)
+{
+ return static_cast<const indexed &>(*e.bp);
+}
-#define ex_to_indexed(X) static_cast<indexed const &>(*(X).bp)
+#ifndef NO_GINAC_NAMESPACE
+} // namespace GiNaC
+#endif // ndef NO_GINAC_NAMESPACE
#endif // ndef __GINAC_INDEXED_H__
-
-