* Implementation of GiNaC's clifford objects.
* No real implementation yet, to be done. */
+/*
+ * 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
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
+
#include <string>
-#include "ginac.h"
+#include "clifford.h"
+#include "ex.h"
+#include "ncmul.h"
#include "utils.h"
+#include "debugmsg.h"
+
+#ifndef NO_NAMESPACE_GINAC
+namespace GiNaC {
+#endif // ndef NO_NAMESPACE_GINAC
//////////
// default constructor, destructor, copy constructor assignment operator and helpers
debugmsg("clifford default constructor",LOGLEVEL_CONSTRUCT);
serial=next_serial++;
name=autoname_prefix()+ToString(serial);
- tinfo_key=TINFO_CLIFFORD;
+ tinfo_key=TINFO_clifford;
}
clifford::~clifford()
destroy(0);
}
-clifford::clifford(clifford const & other)
+clifford::clifford(const clifford & other)
{
debugmsg("clifford copy constructor",LOGLEVEL_CONSTRUCT);
copy (other);
}
-clifford const & clifford::operator=(clifford const & other)
+const clifford & clifford::operator=(const clifford & other)
{
debugmsg("clifford operator=",LOGLEVEL_ASSIGNMENT);
if (this != &other) {
// protected
-void clifford::copy(clifford const & other)
+void clifford::copy(const clifford & other)
{
indexed::copy(other);
name=other.name;
// public
-clifford::clifford(string const & initname)
+clifford::clifford(const string & initname)
{
debugmsg("clifford constructor from string",LOGLEVEL_CONSTRUCT);
name=initname;
serial=next_serial++;
- tinfo_key=TINFO_CLIFFORD;
+ tinfo_key=TINFO_clifford;
}
//////////
// protected
-int clifford::compare_same_type(basic const & other) const
+int clifford::compare_same_type(const basic & other) const
{
- ASSERT(other.tinfo() == TINFO_CLIFFORD);
+ GINAC_ASSERT(other.tinfo() == TINFO_clifford);
const clifford *o = static_cast<const clifford *>(&other);
if (serial==o->serial) {
return indexed::compare_same_type(other);
return serial < o->serial ? -1 : 1;
}
-ex clifford::simplify_ncmul(exvector const & v) const
+ex clifford::simplify_ncmul(const exvector & v) const
{
return simplified_ncmul(v);
}
// non-virtual functions in this class
//////////
-void clifford::setname(string const & n)
+void clifford::setname(const string & n)
{
name=n;
}
//////////
const clifford some_clifford;
-type_info const & typeid_clifford=typeid(some_clifford);
+const type_info & typeid_clifford=typeid(some_clifford);
+#ifndef NO_NAMESPACE_GINAC
+} // namespace GiNaC
+#endif // ndef NO_NAMESPACE_GINAC