ENH: autoLayerDriver: better layering information message
[OpenFOAM-2.0.x.git] / src / OpenFOAM / db / typeInfo / typeInfo.H
blob00981e360576a229be5c74ababe21dc177864ab9
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
4    \\    /   O peration     |
5     \\  /    A nd           | Copyright (C) 2011 OpenFOAM Foundation
6      \\/     M anipulation  |
7 -------------------------------------------------------------------------------
8 License
9     This file is part of OpenFOAM.
11     OpenFOAM is free software: you can redistribute it and/or modify it
12     under the terms of the GNU General Public License as published by
13     the Free Software Foundation, either version 3 of the License, or
14     (at your option) any later version.
16     OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
17     ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
18     FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
19     for more details.
21     You should have received a copy of the GNU General Public License
22     along with OpenFOAM.  If not, see <http://www.gnu.org/licenses/>.
24 Typedef
25     Foam::typeInfo
27 Description
28     Basic run-time type information using word as the type's name.
29     Used to enhance the standard RTTI to cover I/O.
31     The user can get the type's type name using the type info access function
32     \code
33         type()
34     \endcode
36     The reference type cast template function:
37     \code
38         refCast<T>(r)
39     \endcode
41     wraps dynamic_cast to handle the bad_cast exception and generate a
42     FatalError.
44     The isA function:
45     \code
46         isA<T>(r)
47     \endcode
49     returns true if r is of type T or derived from type T.
51 \*---------------------------------------------------------------------------*/
53 #ifndef typeInfo_H
54 #define typeInfo_H
56 #include "error.H"
57 #include "className.H"
58 #include <typeinfo>
60 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
62 // declarations (for use in header files)
64 //- Declare a ClassNameNoDebug() with extra virtual type info
65 #define TypeNameNoDebug(TypeNameString)                                       \
66     ClassNameNoDebug(TypeNameString);                                         \
67     virtual const word& type() const { return typeName; }
69 //- Declare a ClassName() with extra virtual type info
70 #define TypeName(TypeNameString)                                              \
71     ClassName(TypeNameString);                                                \
72     virtual const word& type() const { return typeName; }
75 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
77 namespace Foam
80 // * * * * * * * * * * * * * * * Global Functions  * * * * * * * * * * * * * //
82 //- Reference type cast template function,
83 //  wraps dynamic_cast to handle bad_cast exception and generate a FatalError.
84 template<class To, class From>
85 inline To& dynamicCast(From& r)
87     try
88     {
89         return dynamic_cast<To&>(r);
90     }
91     catch (std::bad_cast)
92     {
93         FatalErrorIn("dynamicCast<To>(From&)")
94             << "Attempt to cast type " << typeid(r).name()
95             << " to type " << typeid(To).name()
96             << abort(FatalError);
98         return dynamic_cast<To&>(r);
99     }
103 //- Reference type cast template function.
104 //  As per dynamicCast, but handles type names via the virtual type() method.
105 template<class To, class From>
106 inline To& refCast(From& r)
108     try
109     {
110         return dynamic_cast<To&>(r);
111     }
112     catch (std::bad_cast)
113     {
114         FatalErrorIn("refCast<To>(From&)")
115             << "Attempt to cast type " << r.type()
116             << " to type " << To::typeName
117             << abort(FatalError);
119         return dynamic_cast<To&>(r);
120     }
124 //- Check the typeid
125 template<class TestType, class Type>
126 inline bool isType(const Type& t)
128     return typeid(t) == typeid(TestType);
132 //- Check if a dynamic_cast to typeid is possible
133 template<class TestType, class Type>
134 inline bool isA(const Type& t)
136     return dynamic_cast<const TestType*>(&t);
140 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
142 } // End namespace Foam
144 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
146 #endif
148 // ************************************************************************* //