Merge branch 'master' of ssh://git.code.sf.net/p/foam-extend/foam-extend-3.2
[foam-extend-3.2.git] / src / foam / fields / DimensionedFields / DimensionedVectorNFields / DimensionedVectorNFields.H
blob3602d8436cfc27f4126eafa301a370315079e140
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | foam-extend: Open Source CFD
4    \\    /   O peration     | Version:     3.2
5     \\  /    A nd           | Web:         http://www.foam-extend.org
6      \\/     M anipulation  | For copyright notice see file Copyright
7 -------------------------------------------------------------------------------
8 License
9     This file is part of foam-extend.
11     foam-extend is free software: you can redistribute it and/or modify it
12     under the terms of the GNU General Public License as published by the
13     Free Software Foundation, either version 3 of the License, or (at your
14     option) any later version.
16     foam-extend is distributed in the hope that it will be useful, but
17     WITHOUT ANY WARRANTY; without even the implied warranty of
18     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
19     General Public License for more details.
21     You should have received a copy of the GNU General Public License
22     along with foam-extend.  If not, see <http://www.gnu.org/licenses/>.
24 Class
25     DimensionedVectorNFields
27 Description
28     Specialisations of DimensionedField<T> for VectorN types.
30 SourceFiles
31     DimensionedVectorNFields.C
33 \*---------------------------------------------------------------------------*/
35 #ifndef DimensionedVectorNFields_H
36 #define DimensionedVectorNFields_H
38 #include "DimensionedField.H"
39 #include "dimensionedVectorTensorN.H"
40 #include "VectorTensorNFields.H"
42 #define TEMPLATE template<class GeoMesh>
43 #include "DimensionedFieldFunctionsM.H"
45 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
47 #define VectorN_FieldFunctions(tensorType, diagTensorType, sphericalTensorType, \
48     vectorType, CmptType, args...)                                              \
49                                                                                 \
50 UNARY_FUNCTION(CmptType, vectorType, cmptSum, cmptSum)                          \
51                                                                                 \
52 BINARY_FUNCTION(vectorType, vectorType, vectorType, cmptMultiply)               \
53 BINARY_TYPE_FUNCTION(vectorType, vectorType, vectorType, cmptMultiply)          \
54                                                                                 \
55 BINARY_OPERATOR(vectorType, CmptType, vectorType, /,'|',divide)                 \
56 BINARY_TYPE_OPERATOR(vectorType, CmptType, vectorType, /,'|',divide)            \
57                                                                                 \
58 BINARY_OPERATOR(vectorType, vectorType, vectorType, +,'+',add)                  \
59 BINARY_OPERATOR(vectorType, vectorType, vectorType, -,'-',subtract)             \
60                                                                                 \
61 BINARY_TYPE_OPERATOR(vectorType, vectorType, vectorType, +,'+',add)             \
62 BINARY_TYPE_OPERATOR(vectorType, vectorType, vectorType, -,'-',subtract)
65 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
67 namespace Foam
70 forAllVectorTensorNTypes(VectorN_FieldFunctions)
74 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
76 #undef VectorN_FieldFunctions
78 #include "undefFieldFunctionsM.H"
80 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
82 #ifdef NoRepository
83 #   include "DimensionedVectorNFields.C"
84 #endif
86 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
88 #endif
90 // ************************************************************************* //