Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042 #ifndef SUNDANCE_OBJECTWITHVERBOSITY_H
00043 #define SUNDANCE_OBJECTWITHVERBOSITY_H
00044
00045 #include "SundanceDefs.hpp"
00046 #include "PlayaObjectWithVerbosity.hpp"
00047 #include "SundanceParamUtils.hpp"
00048 #include "Teuchos_ParameterList.hpp"
00049
00050 namespace Sundance
00051 {
00052
00053 using Teuchos::ParameterList;
00054 using Teuchos::RCP;
00055 using Teuchos::rcp;
00056 using Teuchos::FancyOStream;
00057 using Teuchos::ParameterEntry;
00058
00059
00060
00061
00062
00063 template <class X>
00064 class VerbosityTraits
00065 {
00066 public:
00067 static RCP<ParameterList> defaultVerbParams()
00068 {return X::defaultVerbParams();}
00069 };
00070
00071
00072
00073
00074
00075
00076
00077
00078
00079
00080
00081
00082
00083
00084
00085
00086
00087
00088
00089
00090
00091
00092
00093
00094
00095
00096
00097
00098
00099
00100
00101
00102
00103
00104
00105 template <class X>
00106 class ObjectWithClassVerbosity : public Playa::ObjectWithVerbosity
00107 {
00108 public:
00109
00110 ObjectWithClassVerbosity(int verb=classVerbosity())
00111 : Playa::ObjectWithVerbosity(verb) {;}
00112
00113
00114 static int& classVerbosity()
00115 {
00116 static int rtn = 0;
00117 return rtn;
00118 }
00119
00120 };
00121
00122
00123
00124
00125
00126
00127
00128 template <class X> int& verbosity()
00129 {
00130 return X::classVerbosity();
00131 }
00132
00133 template <class X>
00134 class ParameterControlledObjectWithVerbosity
00135 : public ObjectWithClassVerbosity<X>
00136 {
00137 public:
00138
00139 ParameterControlledObjectWithVerbosity() : ObjectWithClassVerbosity<X>() {;}
00140
00141
00142 ParameterControlledObjectWithVerbosity(const std::string& objName, const ParameterList& p)
00143 : ObjectWithClassVerbosity<X>(),
00144 verbControlParams_()
00145 {
00146 RCP<ParameterList> defaults = VerbosityTraits<X>::defaultVerbParams();
00147 TEUCHOS_TEST_FOR_EXCEPTION(defaults->name() != objName, std::runtime_error,
00148 "mismatched ParameterList names for verbosity control: expected "
00149 << defaults->name() << ", got " << objName);
00150 TEUCHOS_TEST_FOR_EXCEPTION(defaults->name() != p.name(), std::runtime_error,
00151 "mismatched ParameterList names for verbosity control: expected "
00152 << defaults->name() << ", got " << p.name());
00153 verbControlParams_ = rcp(new ParameterList(mergeParams(*defaults, p)));
00154 }
00155
00156
00157 int verbLevel(const std::string& context) const
00158 {
00159 const ParameterEntry* pe = verbControlParams_->getEntryPtr(context);
00160 TEUCHOS_TEST_FOR_EXCEPTION(pe==0, std::runtime_error,
00161 "parameter with name \"" << context << "\" not found in verbosity "
00162 "control parameter list " << verbControlParams_);
00163 TEUCHOS_TEST_FOR_EXCEPTION(pe->getAny().type() != typeid(int),
00164 std::runtime_error,
00165 "context parameter name \""
00166 << context << "\" does not have an integer value in verbosity "
00167 "control parameter list " << verbControlParams_);
00168
00169 return Teuchos::any_cast<int>(pe->getAny());
00170 }
00171
00172
00173 const ParameterList& verbSublist(const std::string& name) const
00174 {
00175 TEUCHOS_TEST_FOR_EXCEPTION(!verbControlParams_->isSublist(name),
00176 std::runtime_error,
00177 "context parameter name \""
00178 << name << "\" is not a sublist in verbosity "
00179 "control parameter list " << *verbControlParams_);
00180
00181 return verbControlParams_->sublist(name);
00182 }
00183
00184
00185 ParameterList mergeParams(const ParameterList& pDef, const ParameterList& pIn) const
00186 {
00187 return mergeParamLists(pDef, pIn);
00188 }
00189
00190
00191 const ParameterList params() const {return *verbControlParams_;}
00192
00193
00194 RCP<ParameterList> modifiableParams() const {return verbControlParams_;}
00195 private:
00196 RCP<ParameterList> verbControlParams_;
00197 };
00198
00199
00200
00201 }
00202
00203
00204
00205
00206
00207 #endif