1
0
mirror of https://github.com/paboyle/Grid.git synced 2024-09-20 09:15:38 +01:00

Hadrons: namespace macro to tackle GCC 5 bug

This commit is contained in:
Antonin Portelli 2016-12-05 14:29:32 +09:00
parent 7a1ac45679
commit 7ae734103e
11 changed files with 252 additions and 237 deletions

View File

@ -39,8 +39,13 @@ namespace Hadrons {\
using Grid::operator<<; using Grid::operator<<;
#define END_HADRONS_NAMESPACE }} #define END_HADRONS_NAMESPACE }}
#define BEGIN_MODULE_NAMESPACE(name)\
namespace name {\
using Grid::operator<<;
#define END_MODULE_NAMESPACE }
/* the 'using Grid::operator<<;' statement prevents a very nasty compilation /* the 'using Grid::operator<<;' statement prevents a very nasty compilation
* error with GCC (clang compiles fine without it). * error with GCC 5 (clang & GCC 6 compile fine without it).
*/ */
// FIXME: find a way to do that in a more general fashion // FIXME: find a way to do that in a more general fashion

View File

@ -37,21 +37,21 @@ BEGIN_HADRONS_NAMESPACE
/****************************************************************************** /******************************************************************************
* Domain wall quark action * * Domain wall quark action *
******************************************************************************/ ******************************************************************************/
namespace MAction BEGIN_MODULE_NAMESPACE(MAction)
class DWFPar: Serializable
{ {
class DWFPar: Serializable public:
{
public:
GRID_SERIALIZABLE_CLASS_MEMBERS(DWFPar, GRID_SERIALIZABLE_CLASS_MEMBERS(DWFPar,
std::string, gauge, std::string, gauge,
unsigned int, Ls, unsigned int, Ls,
double , mass, double , mass,
double , M5); double , M5);
}; };
class DWF: public Module<DWFPar> class DWF: public Module<DWFPar>
{ {
public: public:
// constructor // constructor
DWF(const std::string name); DWF(const std::string name);
// destructor // destructor
@ -63,8 +63,9 @@ namespace MAction
virtual void setup(void); virtual void setup(void);
// execution // execution
virtual void execute(void); virtual void execute(void);
}; };
}
END_MODULE_NAMESPACE
MODULE_REGISTER_NS(DWF, MAction); MODULE_REGISTER_NS(DWF, MAction);

View File

@ -37,19 +37,19 @@ BEGIN_HADRONS_NAMESPACE
/****************************************************************************** /******************************************************************************
* Wilson quark action * * Wilson quark action *
******************************************************************************/ ******************************************************************************/
namespace MAction BEGIN_MODULE_NAMESPACE(MAction)
class WilsonPar: Serializable
{ {
class WilsonPar: Serializable public:
{
public:
GRID_SERIALIZABLE_CLASS_MEMBERS(WilsonPar, GRID_SERIALIZABLE_CLASS_MEMBERS(WilsonPar,
std::string, gauge, std::string, gauge,
double , mass); double , mass);
}; };
class Wilson: public Module<WilsonPar> class Wilson: public Module<WilsonPar>
{ {
public: public:
// constructor // constructor
Wilson(const std::string name); Wilson(const std::string name);
// destructor // destructor
@ -61,8 +61,9 @@ namespace MAction
virtual void setup(void); virtual void setup(void);
// execution // execution
virtual void execute(void); virtual void execute(void);
}; };
}
END_MODULE_NAMESPACE
MODULE_REGISTER_NS(Wilson, MAction); MODULE_REGISTER_NS(Wilson, MAction);

View File

@ -37,27 +37,27 @@ BEGIN_HADRONS_NAMESPACE
/****************************************************************************** /******************************************************************************
* Meson * * Meson *
******************************************************************************/ ******************************************************************************/
namespace MContraction BEGIN_MODULE_NAMESPACE(MContraction)
class MesonPar: Serializable
{ {
class MesonPar: Serializable public:
{
public:
GRID_SERIALIZABLE_CLASS_MEMBERS(MesonPar, GRID_SERIALIZABLE_CLASS_MEMBERS(MesonPar,
std::string, q1, std::string, q1,
std::string, q2, std::string, q2,
std::string, output); std::string, output);
}; };
class Meson: public Module<MesonPar> class Meson: public Module<MesonPar>
{ {
public: public:
class Result: Serializable class Result: Serializable
{ {
public: public:
GRID_SERIALIZABLE_CLASS_MEMBERS(Result, GRID_SERIALIZABLE_CLASS_MEMBERS(Result,
std::vector<std::vector<std::vector<Complex>>>, corr); std::vector<std::vector<std::vector<Complex>>>, corr);
}; };
public: public:
// constructor // constructor
Meson(const std::string name); Meson(const std::string name);
// destructor // destructor
@ -67,8 +67,9 @@ namespace MContraction
virtual std::vector<std::string> getOutput(void); virtual std::vector<std::string> getOutput(void);
// execution // execution
virtual void execute(void); virtual void execute(void);
}; };
}
END_MODULE_NAMESPACE
MODULE_REGISTER_NS(Meson, MContraction); MODULE_REGISTER_NS(Meson, MContraction);

View File

@ -37,18 +37,18 @@ BEGIN_HADRONS_NAMESPACE
/****************************************************************************** /******************************************************************************
* Load a NERSC configuration * * Load a NERSC configuration *
******************************************************************************/ ******************************************************************************/
namespace MGauge BEGIN_MODULE_NAMESPACE(MGauge)
class LoadPar: Serializable
{ {
class LoadPar: Serializable public:
{
public:
GRID_SERIALIZABLE_CLASS_MEMBERS(LoadPar, GRID_SERIALIZABLE_CLASS_MEMBERS(LoadPar,
std::string, file); std::string, file);
}; };
class Load: public Module<LoadPar> class Load: public Module<LoadPar>
{ {
public: public:
// constructor // constructor
Load(const std::string name); Load(const std::string name);
// destructor // destructor
@ -60,8 +60,9 @@ namespace MGauge
virtual void setup(void); virtual void setup(void);
// execution // execution
virtual void execute(void); virtual void execute(void);
}; };
}
END_MODULE_NAMESPACE
MODULE_REGISTER_NS(Load, MGauge); MODULE_REGISTER_NS(Load, MGauge);

View File

@ -37,11 +37,11 @@ BEGIN_HADRONS_NAMESPACE
/****************************************************************************** /******************************************************************************
* Random gauge * * Random gauge *
******************************************************************************/ ******************************************************************************/
namespace MGauge BEGIN_MODULE_NAMESPACE(MGauge)
class Random: public Module<NoPar>
{ {
class Random: public Module<NoPar> public:
{
public:
// constructor // constructor
Random(const std::string name); Random(const std::string name);
// destructor // destructor
@ -53,8 +53,9 @@ namespace MGauge
virtual void setup(void); virtual void setup(void);
// execution // execution
virtual void execute(void); virtual void execute(void);
}; };
}
END_MODULE_NAMESPACE
MODULE_REGISTER_NS(Random, MGauge); MODULE_REGISTER_NS(Random, MGauge);

View File

@ -37,11 +37,11 @@ BEGIN_HADRONS_NAMESPACE
/****************************************************************************** /******************************************************************************
* Unit gauge * * Unit gauge *
******************************************************************************/ ******************************************************************************/
namespace MGauge BEGIN_MODULE_NAMESPACE(MGauge)
class Unit: public Module<NoPar>
{ {
class Unit: public Module<NoPar> public:
{
public:
// constructor // constructor
Unit(const std::string name); Unit(const std::string name);
// destructor // destructor
@ -53,8 +53,9 @@ namespace MGauge
virtual void setup(void); virtual void setup(void);
// execution // execution
virtual void execute(void); virtual void execute(void);
}; };
}
END_MODULE_NAMESPACE
MODULE_REGISTER_NS(Unit, MGauge); MODULE_REGISTER_NS(Unit, MGauge);

View File

@ -37,19 +37,19 @@ BEGIN_HADRONS_NAMESPACE
/****************************************************************************** /******************************************************************************
* Schur red-black preconditioned CG * * Schur red-black preconditioned CG *
******************************************************************************/ ******************************************************************************/
namespace MSolver BEGIN_MODULE_NAMESPACE(MSolver)
class RBPrecCGPar: Serializable
{ {
class RBPrecCGPar: Serializable public:
{
public:
GRID_SERIALIZABLE_CLASS_MEMBERS(RBPrecCGPar, GRID_SERIALIZABLE_CLASS_MEMBERS(RBPrecCGPar,
std::string, action, std::string, action,
double , residual); double , residual);
}; };
class RBPrecCG: public Module<RBPrecCGPar> class RBPrecCG: public Module<RBPrecCGPar>
{ {
public: public:
// constructor // constructor
RBPrecCG(const std::string name); RBPrecCG(const std::string name);
// destructor // destructor
@ -61,8 +61,9 @@ namespace MSolver
virtual void setup(void); virtual void setup(void);
// execution // execution
virtual void execute(void); virtual void execute(void);
}; };
}
END_MODULE_NAMESPACE
MODULE_REGISTER_NS(RBPrecCG, MSolver); MODULE_REGISTER_NS(RBPrecCG, MSolver);

View File

@ -48,18 +48,18 @@ BEGIN_HADRONS_NAMESPACE
/****************************************************************************** /******************************************************************************
* Point * * Point *
******************************************************************************/ ******************************************************************************/
namespace MSource BEGIN_MODULE_NAMESPACE(MSource)
class PointPar: Serializable
{ {
class PointPar: Serializable public:
{
public:
GRID_SERIALIZABLE_CLASS_MEMBERS(PointPar, GRID_SERIALIZABLE_CLASS_MEMBERS(PointPar,
std::string, position); std::string, position);
}; };
class Point: public Module<PointPar> class Point: public Module<PointPar>
{ {
public: public:
// constructor // constructor
Point(const std::string name); Point(const std::string name);
// destructor // destructor
@ -71,8 +71,9 @@ namespace MSource
virtual void setup(void); virtual void setup(void);
// execution // execution
virtual void execute(void); virtual void execute(void);
}; };
}
END_MODULE_NAMESPACE
MODULE_REGISTER_NS(Point, MSource); MODULE_REGISTER_NS(Point, MSource);

View File

@ -49,19 +49,19 @@ BEGIN_HADRONS_NAMESPACE
/****************************************************************************** /******************************************************************************
* Z2 * * Z2 *
******************************************************************************/ ******************************************************************************/
namespace MSource BEGIN_MODULE_NAMESPACE(MSource)
class Z2Par: Serializable
{ {
class Z2Par: Serializable public:
{
public:
GRID_SERIALIZABLE_CLASS_MEMBERS(Z2Par, GRID_SERIALIZABLE_CLASS_MEMBERS(Z2Par,
unsigned int, tA, unsigned int, tA,
unsigned int, tB); unsigned int, tB);
}; };
class Z2: public Module<Z2Par> class Z2: public Module<Z2Par>
{ {
public: public:
// constructor // constructor
Z2(const std::string name); Z2(const std::string name);
// destructor // destructor
@ -73,8 +73,9 @@ namespace MSource
virtual void setup(void); virtual void setup(void);
// execution // execution
virtual void execute(void); virtual void execute(void);
}; };
}
END_MODULE_NAMESPACE
MODULE_REGISTER_NS(Z2, MSource); MODULE_REGISTER_NS(Z2, MSource);

View File

@ -10,18 +10,18 @@ BEGIN_HADRONS_NAMESPACE
/****************************************************************************** /******************************************************************************
* ___FILEBASENAME___ * * ___FILEBASENAME___ *
******************************************************************************/ ******************************************************************************/
namespace ___NAMESPACE___ BEGIN_MODULE_NAMESPACE(___NAMESPACE___)
class ___FILEBASENAME___Par: Serializable
{ {
class ___FILEBASENAME___Par: Serializable public:
{
public:
GRID_SERIALIZABLE_CLASS_MEMBERS(___FILEBASENAME___Par, GRID_SERIALIZABLE_CLASS_MEMBERS(___FILEBASENAME___Par,
unsigned int, i); unsigned int, i);
}; };
class ___FILEBASENAME___: public Module<___FILEBASENAME___Par> class ___FILEBASENAME___: public Module<___FILEBASENAME___Par>
{ {
public: public:
// constructor // constructor
___FILEBASENAME___(const std::string name); ___FILEBASENAME___(const std::string name);
// destructor // destructor
@ -33,8 +33,9 @@ namespace ___NAMESPACE___
virtual void setup(void); virtual void setup(void);
// execution // execution
virtual void execute(void); virtual void execute(void);
}; };
}
END_MODULE_NAMESPACE
MODULE_REGISTER_NS(___FILEBASENAME___, ___NAMESPACE___); MODULE_REGISTER_NS(___FILEBASENAME___, ___NAMESPACE___);