no stl includes in debug.h

change Debug API

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@32675 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Peter Kümmel 2009-12-30 15:09:49 +00:00
parent 0a6118f0c7
commit 75f6ced64b
5 changed files with 36 additions and 18 deletions

View File

@ -957,7 +957,7 @@ int parse_dbg(string const & arg, string const &, string &)
} }
lyxerr << to_utf8(bformat(_("Setting debug level to %1$s"), from_utf8(arg))) << endl; lyxerr << to_utf8(bformat(_("Setting debug level to %1$s"), from_utf8(arg))) << endl;
lyxerr.level(Debug::value(arg)); lyxerr.setLevel(Debug::value(arg));
Debug::showLevel(lyxerr, lyxerr.level()); Debug::showLevel(lyxerr, lyxerr.level());
return 1; return 1;
} }

View File

@ -489,7 +489,7 @@ void LyXFunc::dispatch(FuncRequest const & cmd)
break; break;
case LFUN_DEBUG_LEVEL_SET: case LFUN_DEBUG_LEVEL_SET:
lyxerr.level(Debug::value(to_utf8(cmd.argument()))); lyxerr.setLevel(Debug::value(to_utf8(cmd.argument())));
break; break;
default: default:

View File

@ -62,15 +62,16 @@ GuiProgressView::GuiProgressView(GuiView & parent, Qt::DockWidgetArea area,
widget_->outTE->setFont(font); widget_->outTE->setFont(font);
const std::vector<Debug::Type> levels = Debug::levels(); const int levelCount = Debug::levelCount();
for (unsigned int i = 1; i < levels.size(); i++) { for (int i = 0; i < levelCount; i++) {
LevelButton * box = new LevelButton(toqstr(Debug::description(levels[i]))); const Debug::Type level = Debug::value(i);
box->level = levels[i]; LevelButton * box = new LevelButton(toqstr(Debug::description(level)));
box->level = level;
widget_->settingsLayout->addWidget(box); widget_->settingsLayout->addWidget(box);
// TODO settings // TODO settings
box->setChecked(false); box->setChecked(false);
level_buttons << box; level_buttons << box;
connect(box, SIGNAL(stateChanged(int)), this, SLOT(levelChange())); connect(box, SIGNAL(stateChanged(int)), this, SLOT(levelChanged()));
} }
@ -92,9 +93,15 @@ void GuiProgressView::levelChanged()
int level = Debug::NONE; int level = Debug::NONE;
Q_FOREACH(const LevelButton* button, level_buttons) { Q_FOREACH(const LevelButton* button, level_buttons) {
if (button->isChecked()) if (button->isChecked())
// Debug::NONE overwrites other levels
if (button->level == Debug::NONE) {
lyxerr.setLevel(Debug::NONE);
return;
} else {
level |= button->level; level |= button->level;
} }
lyxerr.level(static_cast<Debug::Type>(level)); }
lyxerr.setLevel(static_cast<Debug::Type>(level));
} }

View File

@ -79,15 +79,20 @@ int const numErrorTags = sizeof(errorTags)/sizeof(errorTags[0]);
} // namespace anon } // namespace anon
const std::vector<Debug::Type> Debug::levels() int Debug::levelCount()
{ {
std::vector<Debug::Type> vec; return numErrorTags;
for (int i = 0 ; i < numErrorTags ; ++i) {
vec.push_back(errorTags[i].level);
} }
return vec;
Debug::Type Debug::value(int idx)
{
if (idx > 0 && idx < numErrorTags)
return errorTags[idx].level;
return Debug::NONE;
} }
string const Debug::description(Debug::Type val) string const Debug::description(Debug::Type val)
{ {
for (int i = 0 ; i < numErrorTags ; ++i) { for (int i = 0 ; i < numErrorTags ; ++i) {

View File

@ -20,7 +20,6 @@
#define LYXDEBUG_H #define LYXDEBUG_H
#include "support/strfwd.h" #include "support/strfwd.h"
#include <vector>
namespace std { namespace std {
@ -108,13 +107,20 @@ namespace Debug {
ANY = 0xffffffff ANY = 0xffffffff
}; };
const std::vector<Type> levels();
// Return number of levels
int levelCount();
/** A function to convert symbolic string names on debug levels /** A function to convert symbolic string names on debug levels
to their numerical value. to their numerical value.
*/ */
Type value(std::string const & val); Type value(std::string const & val);
/** A function to convert index of level to their numerical value.
*/
Type value(int val);
/// Return description of level /// Return description of level
std::string const description(Type val); std::string const description(Type val);
@ -158,7 +164,7 @@ public:
/// Sets stream /// Sets stream
std::ostream & stream() { return *stream_; } std::ostream & stream() { return *stream_; }
/// Sets the debug level to t. /// Sets the debug level to t.
void level(Debug::Type t) { dt = t; } void setLevel(Debug::Type t) { dt = t; }
/// Returns the current debug level. /// Returns the current debug level.
Debug::Type level() const { return dt; } Debug::Type level() const { return dt; }
/// Returns stream /// Returns stream