X-Git-Url: https://www.ginac.de/ginac.git//ginac.git?p=ginac.git;a=blobdiff_plain;f=ginac%2Ffail.cpp;h=d35c2f43e7b81a0ed646545b9842840f2363a4d0;hp=3dc847b9e296dd2b44b0d929ce4c92f7f134fd7f;hb=35d3df76b2ad5e63d7c120f300d7a4b32ee07342;hpb=487e5659efe401683eee0381b0d23f967ffffc3c diff --git a/ginac/fail.cpp b/ginac/fail.cpp index 3dc847b9..d35c2f43 100644 --- a/ginac/fail.cpp +++ b/ginac/fail.cpp @@ -4,7 +4,7 @@ * obsolete all this stuff ought to be replaced by exceptions. */ /* - * 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 @@ -22,6 +22,14 @@ */ #include "fail.h" +#include "archive.h" +#include "debugmsg.h" + +#ifndef NO_NAMESPACE_GINAC +namespace GiNaC { +#endif // ndef NO_NAMESPACE_GINAC + +GINAC_IMPLEMENT_REGISTERED_CLASS(fail, basic) ////////// // default constructor, destructor, copy constructor assignment operator and helpers @@ -29,7 +37,7 @@ // public -fail::fail() : basic(TINFO_fail) +fail::fail() : inherited(TINFO_fail) { debugmsg("fail default constructor",LOGLEVEL_CONSTRUCT); } @@ -40,13 +48,13 @@ fail::~fail() destroy(0); } -fail::fail(fail const & other) +fail::fail(const fail & other) { debugmsg("fail copy constructor",LOGLEVEL_CONSTRUCT); copy(other); } -fail const & fail::operator=(fail const & other) +const fail & fail::operator=(const fail & other) { debugmsg("fail operator=",LOGLEVEL_ASSIGNMENT); if (this != &other) { @@ -58,14 +66,14 @@ fail const & fail::operator=(fail const & other) // protected -void fail::copy(fail const & other) +void fail::copy(const fail & other) { - basic::copy(other); + inherited::copy(other); } void fail::destroy(bool call_parent) { - if (call_parent) basic::destroy(call_parent); + if (call_parent) inherited::destroy(call_parent); } @@ -75,6 +83,28 @@ void fail::destroy(bool call_parent) // none +////////// +// archiving +////////// + +/** Construct object from archive_node. */ +fail::fail(const archive_node &n, const lst &sym_lst) : inherited(n, sym_lst) +{ + debugmsg("fail constructor from archive_node", LOGLEVEL_CONSTRUCT); +} + +/** Unarchive the object. */ +ex fail::unarchive(const archive_node &n, const lst &sym_lst) +{ + return (new fail(n, sym_lst))->setflag(status_flags::dynallocated); +} + +/** Archive the object. */ +void fail::archive(archive_node &n) const +{ + inherited::archive(n); +} + ////////// // functions overriding virtual functions from bases classes ////////// @@ -87,9 +117,21 @@ basic * fail::duplicate() const return new fail(*this); } +void fail::print(ostream & os, unsigned upper_precedence) const +{ + debugmsg("fail print",LOGLEVEL_PRINT); + os << "FAIL"; +} + +void fail::printraw(ostream & os) const +{ + debugmsg("fail printraw",LOGLEVEL_PRINT); + os << "FAIL"; +} + // protected -int fail::compare_same_type(basic const & other) const +int fail::compare_same_type(const basic & other) const { // two fails are always identical return 0; @@ -118,5 +160,8 @@ int fail::compare_same_type(basic const & other) const ////////// const fail some_fail; -type_info const & typeid_fail=typeid(some_fail); +const type_info & typeid_fail=typeid(some_fail); +#ifndef NO_NAMESPACE_GINAC +} // namespace GiNaC +#endif // ndef NO_NAMESPACE_GINAC