Happy New Year!
[ginac.git] / check / exam_structure.cpp
index 3e7b23a..5aa1637 100644 (file)
@@ -3,7 +3,7 @@
  *  Small test for the structure<> template. */
 
 /*
- *  GiNaC Copyright (C) 1999-2005 Johannes Gutenberg University Mainz, Germany
+ *  GiNaC Copyright (C) 1999-2019 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
  *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
  */
 
-#include "exams.h"
+#include "ginac.h"
+using namespace GiNaC;
 
+#include <iostream>
+using namespace std;
 
 struct sprod_s {
        ex left, right;
@@ -47,13 +50,15 @@ inline ex make_sprod(const ex & l, const ex & r)
        return sprod(sprod_s(l, r));
 }
 
+namespace GiNaC {
+
 template <> void sprod::print(const print_context & c, unsigned level) const
 {
        const sprod_s & sp = get_struct();
        c.s << "<" << sp.left << "|" << sp.right << ">";
 }
 
-template <> ex sprod::eval(int level) const
+template <> ex sprod::eval() const
 {
        // symmetric scalar product
        const sprod_s & sp = get_struct();
@@ -63,12 +68,13 @@ template <> ex sprod::eval(int level) const
                return make_sprod(sp.right, sp.left);
 }
 
+}  // namespace GiNaC
+
 unsigned exam_structure()
 {
        unsigned result = 0;
 
        cout << "examining structure template" << flush;
-       clog << "----------structure template:" << endl;
 
        symbol x("x"), y("y");
        ex e;
@@ -87,14 +93,10 @@ unsigned exam_structure()
                ++result;
        }
 
-       cout << '.' << flush;
-
-       if (!result) {
-               cout << " passed " << endl;
-               clog << "(no output)" << endl;
-       } else {
-               cout << " failed " << endl;
-       }
-
        return result;
 }
+
+int main(int argc, char** argv)
+{
+       return exam_structure();
+}