diff --git a/applications/test/contiguous/Make/files b/applications/test/contiguous/Make/files
new file mode 100644
index 0000000000000000000000000000000000000000..56a409b24fd06cf5f04c81a71c7ce2689e0d1534
--- /dev/null
+++ b/applications/test/contiguous/Make/files
@@ -0,0 +1,3 @@
+Test-contiguous.C
+
+EXE = $(FOAM_USER_APPBIN)/Test-contiguous
diff --git a/applications/test/contiguous/Make/options b/applications/test/contiguous/Make/options
new file mode 100644
index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
diff --git a/applications/test/contiguous/Test-contiguous.C b/applications/test/contiguous/Test-contiguous.C
new file mode 100644
index 0000000000000000000000000000000000000000..cfd324a22fa682de06487e4e15009974366a9ea7
--- /dev/null
+++ b/applications/test/contiguous/Test-contiguous.C
@@ -0,0 +1,93 @@
+/*---------------------------------------------------------------------------*\
+  =========                 |
+  \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
+   \\    /   O peration     |
+    \\  /    A nd           | Copyright (C) 2018 OpenCFD Ltd.
+     \\/     M anipulation  |
+-------------------------------------------------------------------------------
+License
+    This file is part of OpenFOAM.
+
+    OpenFOAM is free software: you can redistribute it and/or modify it
+    under the terms of the GNU General Public License as published by
+    the Free Software Foundation, either version 3 of the License, or
+    (at your option) any later version.
+
+    OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
+    ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+    FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+    for more details.
+
+    You should have received a copy of the GNU General Public License
+    along with OpenFOAM.  If not, see <http://www.gnu.org/licenses/>.
+
+Application
+    Test-contiguous
+
+Description
+    Simple test of contiguous data
+
+\*---------------------------------------------------------------------------*/
+
+#include "OSspecific.H"
+#include "argList.H"
+#include "wordRes.H"
+#include "contiguous.H"
+
+#include "IOstreams.H"
+#include "scalar.H"
+#include "vector.H"
+
+#include "labelRange.H"
+#include "scalarList.H"
+#include "HashOps.H"
+#include "FixedList.H"
+#include "Pair.H"
+
+namespace Foam
+{
+
+// Wrong, but interesting to test
+// template<> struct contiguous<Pair<word>> : std::true_type {};
+
+} // end namespace Foam
+
+using namespace Foam;
+
+
+template<class T>
+void printContiguous()
+{
+    Info<<"contiguous " << typeid(T).name() << " () = "
+        << contiguous<T>()
+        // << " value = " << contiguous<T>::value
+        << nl;
+}
+
+
+// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
+//  Main program:
+
+int main(int argc, char *argv[])
+{
+    argList::noBanner();
+    argList::noParallel();
+    argList::noFunctionObjects();
+
+    #include "setRootCase.H"
+
+    printContiguous<label>();
+    printContiguous<double>();
+    printContiguous<FixedList<int, 2>>();
+    printContiguous<FixedList<int, 3>>();
+    printContiguous<Pair<long>>();
+
+    printContiguous<FixedList<word, 2>>();
+    printContiguous<Pair<word>>();
+
+    printContiguous<FixedList<FixedList<int, 2>, 2>>();
+
+    return 0;
+}
+
+// ************************************************************************* //
diff --git a/src/OpenFOAM/primitives/contiguous/contiguous.H b/src/OpenFOAM/primitives/contiguous/contiguous.H
index 902af66dcaa1c6b5f7e64cafad979059794471a1..75eb1ead7fb2cf7e8c3ab3dd4cbd5f99d66405ad 100644
--- a/src/OpenFOAM/primitives/contiguous/contiguous.H
+++ b/src/OpenFOAM/primitives/contiguous/contiguous.H
@@ -36,113 +36,95 @@ Description
 #define contiguous_H
 
 #include "int.H"
+#include <type_traits>
 
 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
 
 namespace Foam
 {
 
-// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
-
-// Forward declaration of friend functions and operators
-template<class T, unsigned Size> class FixedList;
+// Forward declarations
+template<class T, unsigned N> class FixedList;
 template<class T> class Pair;
 
+// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
 
-//- Assume the data associated with type T are not contiguous
+//- Default definition: (integral | floating-point) are contiguous
 template<class T>
-inline bool contiguous()                                   {return false;}
-
+inline bool contiguous()
+{
+    return
+    std::integral_constant
+    <
+        bool,
+        std::is_integral<T>::value || std::is_floating_point<T>::value
+    >::value;
+}
 
-// Data associated with primitive types (and simple fixed size containers
-//  - only size 2 defined here) are contiguous
+//
+// Fixed size containers of (integral | floating-point) are contiguous
+//
 
-template<>
-inline bool contiguous<bool>()                              {return true;}
 template<>
 inline bool contiguous<FixedList<bool, 2>>()               {return true;}
 template<>
 inline bool contiguous<Pair<bool>>()                       {return true;}
 
-template<>
-inline bool contiguous<char>()                              {return true;}
 template<>
 inline bool contiguous<FixedList<char, 2>>()               {return true;}
 template<>
 inline bool contiguous<Pair<char>>()                       {return true;}
 
-template<>
-inline bool contiguous<int8_t>()                            {return true;}
 template<>
 inline bool contiguous<FixedList<int8_t, 2>>()             {return true;}
 template<>
 inline bool contiguous<Pair<int8_t>>()                     {return true;}
 
-template<>
-inline bool contiguous<uint8_t>()                           {return true;}
 template<>
 inline bool contiguous<FixedList<uint8_t, 2>>()            {return true;}
 template<>
 inline bool contiguous<Pair<uint8_t>>()                    {return true;}
 
-template<>
-inline bool contiguous<int16_t>()                           {return true;}
 template<>
 inline bool contiguous<FixedList<int16_t, 2>>()            {return true;}
 template<>
 inline bool contiguous<Pair<int16_t>>()                    {return true;}
 
-template<>
-inline bool contiguous<uint16_t>()                          {return true;}
 template<>
 inline bool contiguous<FixedList<uint16_t, 2>>()           {return true;}
 template<>
 inline bool contiguous<Pair<uint16_t>>()                   {return true;}
 
-template<>
-inline bool contiguous<int32_t>()                           {return true;}
 template<>
 inline bool contiguous<FixedList<int32_t, 2>>()            {return true;}
 template<>
 inline bool contiguous<Pair<int32_t>>()                    {return true;}
 
-template<>
-inline bool contiguous<uint32_t>()                          {return true;}
 template<>
 inline bool contiguous<FixedList<uint32_t, 2>>()           {return true;}
 template<>
 inline bool contiguous<Pair<uint32_t>>()                   {return true;}
 
-template<>
-inline bool contiguous<int64_t>()                           {return true;}
 template<>
 inline bool contiguous<FixedList<int64_t, 2>>()            {return true;}
 template<>
 inline bool contiguous<Pair<int64_t>>()                    {return true;}
 
-template<>
-inline bool contiguous<uint64_t>()                          {return true;}
 template<>
 inline bool contiguous<FixedList<uint64_t, 2>>()           {return true;}
 template<>
 inline bool contiguous<Pair<uint64_t>>()                   {return true;}
 
-template<>
-inline bool contiguous<float>()                             {return true;}
 template<>
 inline bool contiguous<FixedList<float, 2>>()              {return true;}
 template<>
 inline bool contiguous<Pair<float>>()                      {return true;}
 
-template<>
-inline bool contiguous<double>()                            {return true;}
 template<>
 inline bool contiguous<FixedList<double, 2>>()             {return true;}
 template<>
 inline bool contiguous<Pair<double>>()                     {return true;}
 
-template<>
-inline bool contiguous<long double>()                       {return true;}
 template<>
 inline bool contiguous<FixedList<long double, 2>>()        {return true;}
 template<>