X-Git-Url: https://www.ginac.de/ginac.git//ginac.git?a=blobdiff_plain;f=ginac%2Florentzidx.cpp;h=9a0aa7bd34a854e6886a2323f840fd7568cbfa26;hb=d8452c110d6f725c569b8b151d3c78f6e8834536;hp=56b4358c4c86f4b10208d9234e471ba6d6b7f73a;hpb=15d4b353c85f8815a95d97ab977c9ca48e155574;p=ginac.git diff --git a/ginac/lorentzidx.cpp b/ginac/lorentzidx.cpp index 56b4358c..9a0aa7bd 100644 --- a/ginac/lorentzidx.cpp +++ b/ginac/lorentzidx.cpp @@ -23,12 +23,16 @@ #include #include "lorentzidx.h" +#include "lst.h" +#include "archive.h" #include "utils.h" #include "debugmsg.h" -#ifndef NO_GINAC_NAMESPACE +#ifndef NO_NAMESPACE_GINAC namespace GiNaC { -#endif // ndef NO_GINAC_NAMESPACE +#endif // ndef NO_NAMESPACE_GINAC + +GINAC_IMPLEMENT_REGISTERED_CLASS(lorentzidx, idx) ////////// // default constructor, destructor, copy constructor assignment operator and helpers @@ -50,13 +54,13 @@ lorentzidx::~lorentzidx() destroy(0); } -lorentzidx::lorentzidx(lorentzidx const & other) +lorentzidx::lorentzidx(const lorentzidx & other) { debugmsg("lorentzidx copy constructor",LOGLEVEL_CONSTRUCT); copy(other); } -lorentzidx const & lorentzidx::operator=(lorentzidx const & other) +const lorentzidx & lorentzidx::operator=(const lorentzidx & other) { debugmsg("lorentzidx operator=",LOGLEVEL_ASSIGNMENT); if (this != &other) { @@ -68,16 +72,16 @@ lorentzidx const & lorentzidx::operator=(lorentzidx const & other) // protected -void lorentzidx::copy(lorentzidx const & other) +void lorentzidx::copy(const lorentzidx & other) { - idx::copy(other); + inherited::copy(other); orthogonal_only=other.orthogonal_only; dim_parallel_space=other.dim_parallel_space; } void lorentzidx::destroy(bool call_parent) { - if (call_parent) idx::destroy(call_parent); + if (call_parent) inherited::destroy(call_parent); } ////////// @@ -99,7 +103,7 @@ lorentzidx::lorentzidx(bool cov, bool oonly, unsigned dimp) : tinfo_key=TINFO_lorentzidx; } -lorentzidx::lorentzidx(string const & n, bool cov, bool oonly, unsigned dimp) +lorentzidx::lorentzidx(const std::string & n, bool cov, bool oonly, unsigned dimp) : idx(n,cov), orthogonal_only(oonly), dim_parallel_space(dimp) { debugmsg("lorentzidx constructor from string,bool,bool,unsigned", @@ -107,7 +111,7 @@ lorentzidx::lorentzidx(string const & n, bool cov, bool oonly, unsigned dimp) tinfo_key=TINFO_lorentzidx; } -lorentzidx::lorentzidx(char const * n, bool cov, bool oonly, unsigned dimp) +lorentzidx::lorentzidx(const char * n, bool cov, bool oonly, unsigned dimp) : idx(n,cov), orthogonal_only(oonly), dim_parallel_space(dimp) { debugmsg("lorentzidx constructor from char*,bool,bool,unsigned", @@ -115,13 +119,50 @@ lorentzidx::lorentzidx(char const * n, bool cov, bool oonly, unsigned dimp) tinfo_key=TINFO_lorentzidx; } -lorentzidx::lorentzidx(unsigned const v, bool cov) : idx(v,cov), +lorentzidx::lorentzidx(unsigned v, bool cov) : idx(v,cov), orthogonal_only(false), dim_parallel_space(0) { debugmsg("lorentzidx constructor from unsigned,bool",LOGLEVEL_CONSTRUCT); tinfo_key=TINFO_lorentzidx; } +////////// +// archiving +////////// + +/** Construct object from archive_node. */ +lorentzidx::lorentzidx(const archive_node &n, const lst &sym_lst) : inherited(n, sym_lst) +{ + debugmsg("lorentzidx constructor from archive_node", LOGLEVEL_CONSTRUCT); + n.find_bool("orthogonal_only", orthogonal_only); + if (orthogonal_only) + n.find_unsigned("pdim", dim_parallel_space); +} + +/** Unarchive the object. */ +ex lorentzidx::unarchive(const archive_node &n, const lst &sym_lst) +{ + ex s = (new lorentzidx(n, sym_lst))->setflag(status_flags::dynallocated); + + if (ex_to_lorentzidx(s).symbolic) { + // If lorentzidx is in sym_lst, return the existing lorentzidx + for (unsigned i=0; i