diff --git a/Grid/qcd/utils/GaugeGroup.h b/Grid/qcd/utils/GaugeGroup.h index 24b89945..ecd92780 100644 --- a/Grid/qcd/utils/GaugeGroup.h +++ b/Grid/qcd/utils/GaugeGroup.h @@ -2,7 +2,7 @@ Grid physics library, www.github.com/paboyle/Grid -Source file: ./lib/qcd/utils/SUn.h +Source file: ./lib/qcd/utils/GaugeGroup.h Copyright (C) 2015 @@ -32,15 +32,17 @@ directory #ifndef QCD_UTIL_SUN_H #define QCD_UTIL_SUN_H +// Important detail: nvcc requires all template parameters to have names. +// This is the only reason why the second template parameter has a name. #define ONLY_IF_SU \ typename dummy_name = group_name, \ - typename = std::enable_if_t < \ + typename named_dummy = std::enable_if_t < \ std::is_same::value && \ is_su::value > #define ONLY_IF_Sp \ typename dummy_name = group_name, \ - typename = std::enable_if_t < \ + typename named_dummy = std::enable_if_t < \ std::is_same::value && \ is_sp::value > @@ -143,8 +145,8 @@ class GaugeGroup { typedef Lattice LatticeSU2MatrixF; typedef Lattice LatticeSU2MatrixD; -#include "Grid/qcd/utils/SUn.h" -#include "Grid/qcd/utils/Sp2n.h" +#include "Grid/qcd/utils/SUn.impl" +#include "Grid/qcd/utils/Sp2n.impl" public: template diff --git a/Grid/qcd/utils/SUn.h b/Grid/qcd/utils/SUn.impl similarity index 99% rename from Grid/qcd/utils/SUn.h rename to Grid/qcd/utils/SUn.impl index 61b19fbc..eaf82877 100644 --- a/Grid/qcd/utils/SUn.h +++ b/Grid/qcd/utils/SUn.impl @@ -5,6 +5,9 @@ // class GaugeGroup { // // around it. +// +// Please note that the unconventional file extension makes sure that it +// doesn't get found by the scripts/filelist during bootstrapping. private: static int su2subgroups(GroupName::SU) { return (ncolour * (ncolour - 1)) / 2; } diff --git a/Grid/qcd/utils/Sp2n.h b/Grid/qcd/utils/Sp2n.impl similarity index 96% rename from Grid/qcd/utils/Sp2n.h rename to Grid/qcd/utils/Sp2n.impl index 6d559c0a..c8ed2ddc 100644 --- a/Grid/qcd/utils/Sp2n.h +++ b/Grid/qcd/utils/Sp2n.impl @@ -1,3 +1,13 @@ +// This file is #included into the body of the class template definition of +// GaugeGroup. So, image there to be +// +// template +// class GaugeGroup { +// +// around it. +// +// Please note that the unconventional file extension makes sure that it +// doesn't get found by the scripts/filelist during bootstrapping. private: static int su2subgroups(GroupName::Sp) { return (ncolour/2 * (ncolour/2 - 1)) / 2; }