bbtkMessageManager.cxx
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
00035 #include "bbtkMessageManager.h"
00036
00037 namespace bbtk
00038 {
00039
00040 MessageManager::MessageManager()
00041 : mMaxMessageLength(8)
00042
00043 {
00044 std::string key;
00045 key ="all";
00046 mMessageLevel[key] = 0;
00047 mMessageHelp[key] = "Minimum level for all kind of messages";
00048 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00049 key ="max";
00050 mMessageLevel[key] = 9;
00051 mMessageHelp[key] = "Maximum level for all kind of messages";
00052 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00053 key ="kernel";
00054 mMessageLevel[key] = 0;
00055 mMessageHelp[key] = "Messages generated by the core classes of the lib";
00056 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00057 key ="process";
00058 mMessageLevel[key] = 0;
00059 mMessageHelp[key] = "Messages related to box processing";
00060 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00061 key = "help";
00062 mMessageLevel[key] = 1;
00063 mMessageHelp[key] = "Help messages";
00064 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00065 key = "error";
00066 mMessageLevel[key] = 0;
00067 mMessageHelp[key] = "Error messages";
00068 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00069 key = "warning";
00070 mMessageLevel[key] = 1;
00071 mMessageHelp[key] = "Warning messages";
00072 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00073 key = "output";
00074 mMessageLevel[key] = 1;
00075 mMessageHelp[key] = "Output messages";
00076 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00077 key = "debug";
00078 mMessageLevel[key] = 0;
00079 mMessageHelp[key] = "Debug messages";
00080 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00081 key = "config";
00082 mMessageLevel[key] = 0;
00083 mMessageHelp[key] = "Configuration related messages";
00084 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00085 key = "data";
00086 mMessageLevel[key] = 0;
00087 mMessageHelp[key] = "Data related messages";
00088 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00089 key = "widget";
00090 mMessageLevel[key] = 0;
00091 mMessageHelp[key] = "Widgets related messages";
00092 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00093 key = "wx";
00094 mMessageLevel[key] = 0;
00095 mMessageHelp[key] = "wxWidgets related messages";
00096 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00097 key = "qt";
00098 mMessageLevel[key] = 0;
00099 mMessageHelp[key] = "Qt related messages";
00100 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00101 key = "gui";
00102 mMessageLevel[key] = 0;
00103 mMessageHelp[key] = "Graphical user interface related messages";
00104 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00105 key = "object";
00106 mMessageLevel[key] = 0;
00107 mMessageHelp[key] = "object memory related messages";
00108 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00109 key = "package";
00110 mMessageLevel[key] = 0;
00111 mMessageHelp[key] = "Packages related messages";
00112 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00113 key = "connection";
00114 mMessageLevel[key] = 0;
00115 mMessageHelp[key] = "Connections related messages";
00116 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00117 key = "change";
00118 mMessageLevel[key] = 0;
00119 mMessageHelp[key] = "Box i/o changes related messages";
00120 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00121 key = "code";
00122 mMessageLevel[key] = 0;
00123 mMessageHelp[key] = "If positive then codes of the messages are displayed";
00124 if (mMaxMessageLength<key.length()) mMaxMessageLength = key.length();
00125 }
00126
00127
00128
00129
00130 MessageManager::~MessageManager()
00131 {
00132
00133 }
00134
00135
00136
00137 MessageManager* MessageManager::GetInstance()
00138 {
00139 static MessageManager* m = 0;
00140 if (!m) m = new MessageManager();
00141 return m;
00142 }
00143
00144 bool MessageManager::RegisterMessageType(std::string key,
00145 std::string help,
00146 unsigned char default_level)
00147 {
00148 GetInstance()->mMessageLevel[key] = default_level;
00149 GetInstance()->mMessageHelp[key] = help;
00150 if (GetInstance()->mMaxMessageLength<key.length())
00151 GetInstance()->mMaxMessageLength = key.length();
00152 return true;
00153 }
00154
00155
00156
00157
00158 void MessageManager::SetMessageLevel(std::string key,
00159 unsigned char level)
00160 {
00161 std::map<std::string,int>::iterator i;
00162 i = GetInstance()->mMessageLevel.find(key);
00163 if (i!=GetInstance()->mMessageLevel.end())
00164 {
00165 (*i).second = level;
00166 }
00167 else
00168 {
00169 bbtkWarning("MessageManager::SetMessageLevel : message type=<"
00170 <<key<<"> unregistered");
00171 }
00172
00173 }
00174
00175
00176
00177 int MessageManager::GetMessageLevel(std::string key)
00178 {
00179 int l = GetInstance()->mMessageLevel["all"];
00180 std::map<std::string,int>::iterator i =
00181 GetInstance()->mMessageLevel.find(key);
00182 if (i!=GetInstance()->mMessageLevel.end()) {
00183 if ( (*i).second > l ) l = (*i).second;
00184 }
00185 int m = GetInstance()->mMessageLevel["max"];
00186 if (l>m) l=m;
00187 return l;
00188 }
00189
00190
00191
00192 void MessageManager::PrintInfo()
00193 {
00194 bbtkMessage("help",1,"================ Messages ================="
00195 << bbtkendl);
00196 bbtkMessage("help",1, "Kind");
00197 for (int k=0;
00198 k<(int)(GetInstance()->mMaxMessageLength-2);
00199 k++)
00200 {
00201 bbtkMessageCont("help",1," ");
00202 }
00203 bbtkMessageCont("help",1,"Level Nature" << bbtkendl);
00204 std::map<std::string,int>::iterator i;
00205 std::map<std::string,std::string>::iterator j;
00206 for (i=GetInstance()->mMessageLevel.begin(),
00207 j=GetInstance()->mMessageHelp.begin();
00208 i!=GetInstance()->mMessageLevel.end();++i,++j) {
00209 bbtkMessage("help",1, (*i).first);
00210 for (int k=0;
00211 k<(int)(GetInstance()->mMaxMessageLength+2-(*i).first.length());
00212 k++) {
00213 bbtkMessageCont("help",1," ");
00214 }
00215 bbtkMessageCont("help",1, (*i).second << "\t"
00216 << (*j).second << bbtkendl);
00217 }
00218 bbtkMessage("help",1,"==========================================="
00219 << bbtkendl);
00220 }
00221
00222 std::string MessageManager::FormatKey(const std::string& key,
00223 int value)
00224 {
00225 std::string s;
00226 if ( GetInstance()->mMessageLevel["code"] != 0 )
00227 {
00228 s = key.substr(0,4);
00229 std::stringstream ss;
00230 ss << value;
00231
00232 s += ss.str();
00233 s += "> ";
00234 }
00235 return s;
00236 }
00237 }