|
Teuchos - Trilinos Tools Package
Version of the Day
|
00001 // @HEADER 00002 // *********************************************************************** 00003 // 00004 // Teuchos: Common Tools Package 00005 // Copyright (2004) Sandia Corporation 00006 // 00007 // Under terms of Contract DE-AC04-94AL85000, there is a non-exclusive 00008 // license for use of this work by or on behalf of the U.S. Government. 00009 // 00010 // Redistribution and use in source and binary forms, with or without 00011 // modification, are permitted provided that the following conditions are 00012 // met: 00013 // 00014 // 1. Redistributions of source code must retain the above copyright 00015 // notice, this list of conditions and the following disclaimer. 00016 // 00017 // 2. Redistributions in binary form must reproduce the above copyright 00018 // notice, this list of conditions and the following disclaimer in the 00019 // documentation and/or other materials provided with the distribution. 00020 // 00021 // 3. Neither the name of the Corporation nor the names of the 00022 // contributors may be used to endorse or promote products derived from 00023 // this software without specific prior written permission. 00024 // 00025 // THIS SOFTWARE IS PROVIDED BY SANDIA CORPORATION "AS IS" AND ANY 00026 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00027 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 00028 // PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SANDIA CORPORATION OR THE 00029 // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 00030 // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 00031 // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 00032 // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF 00033 // LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING 00034 // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 00035 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00036 // 00037 // Questions? Contact Michael A. Heroux (maherou@sandia.gov) 00038 // 00039 // *********************************************************************** 00040 // @HEADER 00041 00042 #ifndef TEUCHOS_DESCRIBABLE_HPP 00043 #define TEUCHOS_DESCRIBABLE_HPP 00044 00045 #include "Teuchos_VerbosityLevel.hpp" 00046 #include "Teuchos_FancyOStream.hpp" 00047 #include "Teuchos_LabeledObject.hpp" 00048 00049 00050 namespace Teuchos { 00051 00052 00076 class TEUCHOSCORE_LIB_DLL_EXPORT Describable : virtual public LabeledObject { 00077 public: 00079 static const EVerbosityLevel verbLevel_default; 00080 00082 00083 00095 virtual std::string description() const; 00096 00148 virtual void 00149 describe (FancyOStream &out, 00150 const EVerbosityLevel verbLevel = verbLevel_default) const; 00151 00162 void 00163 describe (std::ostream &out, 00164 const EVerbosityLevel verbLevel = verbLevel_default) const; 00165 00167 virtual ~Describable (); 00168 }; 00169 00170 00171 // Describable stream manipulator state class 00172 // 00173 // This is not a class that a user needs to see and that is why it is not 00174 // being given doxygen documentation! 00175 struct DescribableStreamManipulatorState { 00176 const Describable &describable; 00177 const EVerbosityLevel verbLevel; 00178 DescribableStreamManipulatorState( 00179 const Describable &_describable, 00180 const EVerbosityLevel _verbLevel = VERB_MEDIUM 00181 ) 00182 :describable(_describable) 00183 ,verbLevel(_verbLevel) 00184 {} 00185 }; 00186 00187 00209 inline DescribableStreamManipulatorState describe( 00210 const Describable &describable, 00211 const EVerbosityLevel verbLevel = Describable::verbLevel_default 00212 ) 00213 { 00214 return DescribableStreamManipulatorState(describable,verbLevel); 00215 } 00216 00217 00244 inline 00245 std::ostream& operator<<( 00246 std::ostream& os, const DescribableStreamManipulatorState& d 00247 ) 00248 { 00249 d.describable.describe(*getFancyOStream(Teuchos::rcp(&os,false)),d.verbLevel); 00250 return os; 00251 } 00252 00253 // 00254 // RAB: Note: The above function works with an std::ostream object even 00255 // through Describable::describe(...) requires a FancyOStream object. We must 00256 // write the stream manipulator in terms of std::ostream, or compound output 00257 // statements like: 00258 // 00259 // void foo( FancyOStream &out, Describable &d, EVerbLevel verbLevel ) 00260 // { 00261 // out << "\nThis is the describable object d:" << describe(d,verbLevel); 00262 // } 00263 // 00264 // will not work correctly. The problem is that the first output 00265 // 00266 // out << "\nThis is the describable object d:" 00267 // 00268 // must return a reference to an std::ostream object. This should mean that 00269 // the next statement, which is basically: 00270 // 00271 // static_cast<std::ostream&>(out) << DescribableStreamManipulatorState 00272 // 00273 // should not even compile. However, under gcc 3.4.3, the code did compile 00274 // but did not call the above function. Instead, it set up some type of 00275 // infinite recursion that resulted in a segfault due to the presence of the 00276 // Teuchos::any class! 00277 // 00278 00279 00280 } // namespace Teuchos 00281 00282 #endif // TEUCHOS_DESCRIBABLE_HPP
1.7.6.1