[PATCH] qconf: (re)fix SIGSEGV on empty menu items

Back out the recent fix for this bug, fix it by correctly initialising
ConfigInfoView.sym.

Signed-off-by: Roman Zippel <zippel@linux-m68k.org>
Cc: "Cyrill V. Gorcunov" <gorcunov@gmail.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
Roman Zippel 2007-01-10 23:15:31 -08:00 коммит произвёл Linus Torvalds
Родитель a2f3aa0257
Коммит 6fa1da8ea9
2 изменённых файлов: 4 добавлений и 13 удалений

Просмотреть файл

@ -917,7 +917,7 @@ void ConfigView::updateListAll(void)
}
ConfigInfoView::ConfigInfoView(QWidget* parent, const char *name)
: Parent(parent, name), menu(0)
: Parent(parent, name), menu(0), sym(0)
{
if (name) {
configSettings->beginGroup(name);
@ -925,8 +925,6 @@ ConfigInfoView::ConfigInfoView(QWidget* parent, const char *name)
configSettings->endGroup();
connect(configApp, SIGNAL(aboutToQuit()), SLOT(saveSettings()));
}
has_dbg_info = 0;
}
void ConfigInfoView::saveSettings(void)
@ -955,13 +953,11 @@ void ConfigInfoView::setInfo(struct menu *m)
if (menu == m)
return;
menu = m;
if (!menu) {
has_dbg_info = 0;
sym = NULL;
if (!menu)
clear();
} else {
has_dbg_info = 1;
else
menuInfo();
}
}
void ConfigInfoView::setSource(const QString& name)
@ -996,9 +992,6 @@ void ConfigInfoView::symbolInfo(void)
{
QString str;
if (!has_dbg_info)
return;
str += "<big>Symbol: <b>";
str += print_filter(sym->name);
str += "</b></big><br><br>value: ";

Просмотреть файл

@ -273,8 +273,6 @@ protected:
struct symbol *sym;
struct menu *menu;
bool _showDebug;
int has_dbg_info;
};
class ConfigSearchWindow : public QDialog {