Commit 022b6f08 authored by Richard Shepherd's avatar Richard Shepherd

"File|Open DVD" menu now refreshed each time menu selected rather than...

"File|Open DVD" menu now refreshed each time menu selected rather than statically built at execute time.
parent 1bc9a658
...@@ -22,6 +22,16 @@ ...@@ -22,6 +22,16 @@
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA. * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
*****************************************************************************/ *****************************************************************************/
class CDMenu : public BMenu
{
public:
CDMenu(const char *name);
~CDMenu();
void AttachedToWindow(void);
private:
int GetCD(const char *directory);
};
class InterfaceWindow : public BWindow class InterfaceWindow : public BWindow
{ {
public: public:
...@@ -41,8 +51,6 @@ public: ...@@ -41,8 +51,6 @@ public:
bool fSeeking; bool fSeeking;
BFilePanel *file_panel; BFilePanel *file_panel;
private:
int GetCD(const char *directory, BMenu *cd_menu);
}; };
class InterfaceView : public BView class InterfaceView : public BView
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* intf_beos.cpp: beos interface * intf_beos.cpp: beos interface
***************************************************************************** *****************************************************************************
* Copyright (C) 1999, 2000, 2001 VideoLAN * Copyright (C) 1999, 2000, 2001 VideoLAN
* $Id: intf_beos.cpp,v 1.18 2001/03/06 19:52:03 richards Exp $ * $Id: intf_beos.cpp,v 1.19 2001/03/07 16:32:59 richards Exp $
* *
* Authors: Jean-Marc Dressler <polux@via.ecp.fr> * Authors: Jean-Marc Dressler <polux@via.ecp.fr>
* Samuel Hocevar <sam@zoy.org> * Samuel Hocevar <sam@zoy.org>
...@@ -120,13 +120,14 @@ InterfaceWindow::InterfaceWindow( BRect frame, const char *name , intf_thread_t ...@@ -120,13 +120,14 @@ InterfaceWindow::InterfaceWindow( BRect frame, const char *name , intf_thread_t
menu_bar = new BMenuBar(rect, "main menu"); menu_bar = new BMenuBar(rect, "main menu");
AddChild( menu_bar ); AddChild( menu_bar );
BMenu *m, *cd_menu; BMenu *m;
CDMenu *cd_menu;
menu_bar->AddItem( m = new BMenu("File") ); menu_bar->AddItem( m = new BMenu("File") );
menu_bar->ResizeToPreferred(); menu_bar->ResizeToPreferred();
m->AddItem( new BMenuItem("Open File...", new BMessage(OPEN_FILE), 'O')); m->AddItem( new BMenuItem("Open File...", new BMessage(OPEN_FILE), 'O'));
cd_menu = new BMenu("Open DVD"); cd_menu = new CDMenu("Open DVD");
GetCD("/dev/disk", cd_menu); //GetCD("/dev/disk", cd_menu);
m->AddItem(cd_menu); m->AddItem(cd_menu);
m->AddSeparatorItem(); m->AddSeparatorItem();
m->AddItem( new BMenuItem("About...", new BMessage(B_ABOUT_REQUESTED), 'A')); m->AddItem( new BMenuItem("About...", new BMessage(B_ABOUT_REQUESTED), 'A'));
...@@ -409,8 +410,42 @@ bool InterfaceWindow::QuitRequested() ...@@ -409,8 +410,42 @@ bool InterfaceWindow::QuitRequested()
return( false ); return( false );
} }
/*****************************************************************************
* CDMenu::CDMenu
*****************************************************************************/
CDMenu::CDMenu(const char *name)
: BMenu(name)
{
}
/*****************************************************************************
* CDMenu::~CDMenu
*****************************************************************************/
CDMenu::~CDMenu()
{
}
/*****************************************************************************
* CDMenu::AttachedToWindow
*****************************************************************************/
void CDMenu::AttachedToWindow(void)
{
int32 items = CountItems();
for(int32 i = 0; i < items; i++)
RemoveItem(i);
GetCD("/dev/disk");
BMenu::AttachedToWindow();
}
/*****************************************************************************
* CDMenu::GetCD
*****************************************************************************/
int InterfaceWindow::GetCD(const char *directory, BMenu *cd_menu) int CDMenu::GetCD(const char *directory)
{ {
BDirectory dir; BDirectory dir;
dir.SetTo(directory); dir.SetTo(directory);
...@@ -435,7 +470,7 @@ int InterfaceWindow::GetCD(const char *directory, BMenu *cd_menu) ...@@ -435,7 +470,7 @@ int InterfaceWindow::GetCD(const char *directory, BMenu *cd_menu)
if(entry.IsDirectory()) { if(entry.IsDirectory()) {
if(strcmp(e.name, "floppy") == 0) if(strcmp(e.name, "floppy") == 0)
continue; // ignore floppy (it is not silent) continue; // ignore floppy (it is not silent)
int devfd = GetCD(name, cd_menu); int devfd = GetCD(name);
if(devfd >= 0) if(devfd >= 0)
{ {
return devfd; return devfd;
...@@ -464,7 +499,7 @@ int InterfaceWindow::GetCD(const char *directory, BMenu *cd_menu) ...@@ -464,7 +499,7 @@ int InterfaceWindow::GetCD(const char *directory, BMenu *cd_menu)
msg->AddString("device", name); msg->AddString("device", name);
BMenuItem *menu_item; BMenuItem *menu_item;
menu_item = new BMenuItem(name, msg); menu_item = new BMenuItem(name, msg);
cd_menu->AddItem(menu_item); AddItem(menu_item);
continue; continue;
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment