* BUG: Fix the crash after menu deletion.
* BUG: The menu bar is visible in all cases now the first time it is shown.


git-svn-id: svn://localhost/gambas/trunk@2395 867c0c6c-44f3-4631-809d-bfa615b0a4ec
This commit is contained in:
Benoît Minisini 2009-10-19 13:34:21 +00:00
parent 25c43c72c4
commit afef1f3472
2 changed files with 22 additions and 20 deletions

View File

@ -73,6 +73,9 @@ static void refresh_menubar(CMENU *menu)
for (i = 0; i < list.count(); i++) for (i = 0; i < list.count(); i++)
{ {
action = list.at(i); action = list.at(i);
menu = CMenu::dict[action];
if (!menu || menu->deleted)
continue;
if (action->isVisible() && !action->isSeparator()) if (action->isVisible() && !action->isSeparator())
break; break;
} }
@ -86,6 +89,14 @@ static void unregister_menu(CMENU *_object)
CACTION_register((CWIDGET *)THIS, NULL); CACTION_register((CWIDGET *)THIS, NULL);
} }
static void set_menu_visible(void *_object, bool v)
{
THIS->visible = v;
ACTION->setVisible(v);
refresh_menubar(THIS);
//update_accel_recursive(THIS);
}
static void delete_menu(CMENU *_object) static void delete_menu(CMENU *_object)
{ {
if (THIS->deleted) if (THIS->deleted)
@ -105,13 +116,13 @@ static void delete_menu(CMENU *_object)
delete THIS->accel; delete THIS->accel;
THIS->deleted = true; THIS->deleted = true;
QAction *action = ACTION;
CMenu::dict.remove(action);
refresh_menubar(THIS); if (ACTION)
{
delete action; refresh_menubar(THIS);
delete ACTION;
}
// if (ACTION) // if (ACTION)
// { // {
// QAction *action = ACTION; // QAction *action = ACTION;
@ -134,7 +145,8 @@ static void clear_menu(CMENU *_object)
menu = CMenu::dict[list.at(i)]; menu = CMenu::dict[list.at(i)];
//GB.Ref(menu); //GB.Ref(menu);
//delete ((QAction *)(menu->widget.widget)); //delete ((QAction *)(menu->widget.widget));
delete_menu(menu); if (menu)
delete_menu(menu);
//GB.Unref(POINTER(&menu)); //GB.Unref(POINTER(&menu));
} }
} }
@ -206,13 +218,6 @@ static void update_check(CMENU *_object)
} }
} }
static void set_menu_visible(void *_object, bool v)
{
THIS->visible = v;
ACTION->setVisible(v);
//update_accel_recursive(THIS);
}
#if 0 #if 0
static void toggle_menu(CMENU *_object) static void toggle_menu(CMENU *_object)
{ {
@ -353,8 +358,8 @@ BEGIN_PROPERTY(CMENU_text)
else else
{ {
QString text = QSTRING_PROP(); QString text = QSTRING_PROP();
ACTION->setText(text);
ACTION->setSeparator(text.isNull()); ACTION->setSeparator(text.isNull());
ACTION->setText(text);
refresh_menubar(THIS); refresh_menubar(THIS);
} }
@ -480,10 +485,7 @@ BEGIN_PROPERTY(CMENU_visible)
if (READ_PROPERTY) if (READ_PROPERTY)
GB.ReturnBoolean(THIS->visible); GB.ReturnBoolean(THIS->visible);
else else
{
set_menu_visible(THIS, VPROP(GB_BOOLEAN)); set_menu_visible(THIS, VPROP(GB_BOOLEAN));
refresh_menubar(THIS);
}
END_PROPERTY END_PROPERTY
@ -491,7 +493,6 @@ END_PROPERTY
BEGIN_METHOD_VOID(CMENU_show) BEGIN_METHOD_VOID(CMENU_show)
set_menu_visible(THIS, true); set_menu_visible(THIS, true);
refresh_menubar(THIS);
END_METHOD END_METHOD
@ -499,7 +500,6 @@ END_METHOD
BEGIN_METHOD_VOID(CMENU_hide) BEGIN_METHOD_VOID(CMENU_hide)
set_menu_visible(THIS, false); set_menu_visible(THIS, false);
refresh_menubar(THIS);
END_METHOD END_METHOD
@ -830,6 +830,7 @@ void CMenu::slotDestroyed(void)
if (!_object) if (!_object)
return; return;
CMenu::dict.remove(ACTION);
//qDebug("CMenu::slotDestroyed: (%s %p)", GB.GetClassName(THIS), THIS); //qDebug("CMenu::slotDestroyed: (%s %p)", GB.GetClassName(THIS), THIS);
//if (THIS->menu) //if (THIS->menu)

View File

@ -2267,6 +2267,7 @@ void MyMainWindow::configure()
{ {
h = menuBar->sizeHint().height(); h = menuBar->sizeHint().height();
menuBar->setGeometry(0, 0, this->width(), h); menuBar->setGeometry(0, 0, this->width(), h);
menuBar->show();
THIS->container->setGeometry(0, h, this->width(), this->height() - h); THIS->container->setGeometry(0, h, this->width(), this->height() - h);
} }
else else