/*****************************************************************************
* open.cpp : Advanced open dialog
*****************************************************************************
- * Copyright © 2006-2007 the VideoLAN team
+ * Copyright © 2006-2009 the VideoLAN team
* $Id$
*
* Authors: Jean-Baptiste Kempf <jb@videolan.org>
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/
+
#ifdef HAVE_CONFIG_H
# include "config.h"
#endif
-#include "input_manager.hpp"
-
#include "dialogs/open.hpp"
+#include "dialogs_provider.hpp"
+
+#include "recents.hpp"
+
#include <QTabWidget>
#include <QGridLayout>
-#include <QFileDialog>
#include <QRegExp>
#include <QMenu>
OpenDialog *OpenDialog::instance = NULL;
OpenDialog* OpenDialog::getInstance( QWidget *parent, intf_thread_t *p_intf,
- bool b_rawInstance, int _action_flag, bool b_selectMode )
+ bool b_rawInstance, int _action_flag, bool b_selectMode, bool _b_pl )
{
/* Creation */
if( !instance )
- instance = new OpenDialog( parent, p_intf, b_selectMode, _action_flag );
+ instance = new OpenDialog( parent, p_intf, b_selectMode,
+ _action_flag, _b_pl );
else if( !b_rawInstance )
{
/* Request the instance but change small details:
if the call is correct */
}
instance->i_action_flag = _action_flag;
+ instance->b_pl = _b_pl;
instance->setMenuAction();
}
return instance;
OpenDialog::OpenDialog( QWidget *parent,
intf_thread_t *_p_intf,
bool b_selectMode,
- int _action_flag ) : QVLCDialog( parent, _p_intf )
+ int _action_flag,
+ bool _b_pl) : QVLCDialog( parent, _p_intf )
{
i_action_flag = _action_flag;
+ b_pl =_b_pl;
+
+ /* Workaround the Win32 Vout that put the video on top at regular times */
+#ifdef WIN32
+ setWindowFlags( Qt::WindowStaysOnTopHint | Qt::Dialog );
+#endif
if( b_selectMode ) /* Select mode */
{
- setWindowModality( Qt::WindowModal );
i_action_flag = SELECT;
+ setWindowModality( Qt::WindowModal );
}
/* Basic Creation of the Window */
ui.setupUi( this );
- setWindowTitle( qtr( "Open" ) );
- /* resize( 410, 600 ); */
- setMinimumSize( 520, 460 );
+ setWindowTitle( qtr( "Open a Media" ) );
/* Tab definition and creation */
fileOpenPanel = new FileOpenPanel( ui.Tab, p_intf );
setMenuAction();
/* Force MRL update on tab change */
- CONNECT( ui.Tab, currentChanged( int ), this, signalCurrent() );
+ CONNECT( ui.Tab, currentChanged( int ), this, signalCurrent( int ) );
- CONNECT( fileOpenPanel, mrlUpdated( QString ), this, updateMRL( QString ) );
- CONNECT( netOpenPanel, mrlUpdated( QString ), this, updateMRL( QString ) );
- CONNECT( discOpenPanel, mrlUpdated( QString ), this, updateMRL( QString ) );
- CONNECT( captureOpenPanel, mrlUpdated( QString ), this, updateMRL( QString ) );
+ CONNECT( fileOpenPanel, mrlUpdated( QStringList, QString ),
+ this, updateMRL( QStringList, QString ) );
+ CONNECT( netOpenPanel, mrlUpdated( QStringList, QString ),
+ this, updateMRL( QStringList, QString ) );
+ CONNECT( discOpenPanel, mrlUpdated( QStringList, QString ),
+ this, updateMRL( QStringList, QString ) );
+ CONNECT( captureOpenPanel, mrlUpdated( QStringList, QString ),
+ this, updateMRL( QStringList, QString ) );
CONNECT( fileOpenPanel, methodChanged( QString ),
this, newCachingMethod( QString ) );
this, newCachingMethod( QString ) );
/* Advanced frame Connects */
+ CONNECT( ui.slaveCheckbox, toggled( bool ), this, updateMRL() );
CONNECT( ui.slaveText, textChanged( QString ), this, updateMRL() );
CONNECT( ui.cacheSpinBox, valueChanged( int ), this, updateMRL() );
CONNECT( ui.startTimeSpinBox, valueChanged( int ), this, updateMRL() );
/* Initialize caching */
storedMethod = "";
newCachingMethod( "file-caching" );
+
+ resize( getSettings()->value( "opendialog-size", QSize( 400, 490 ) ).toSize() );
}
OpenDialog::~OpenDialog()
-{}
+{
+ getSettings()->setValue( "opendialog-size", size() );
+}
+
+/* Used by VLM dialog and inputSlave selection */
+QString OpenDialog::getMRL( bool b_all )
+{
+ if( itemsMRL.size() == 0 ) return "";
+ return b_all ? itemsMRL[0] + ui.advancedLineInput->text()
+ : itemsMRL[0];
+}
/* Finish the dialog and decide if you open another one after */
void OpenDialog::setMenuAction()
void OpenDialog::showTab( int i_tab )
{
+ if( i_tab == OPEN_CAPTURE_TAB ) captureOpenPanel->initialize();
ui.Tab->setCurrentIndex( i_tab );
show();
}
/* Function called on signal currentChanged triggered */
-void OpenDialog::signalCurrent()
+void OpenDialog::signalCurrent( int i_tab )
{
+ if( i_tab == OPEN_CAPTURE_TAB ) captureOpenPanel->initialize();
+
if( ui.Tab->currentWidget() != NULL )
( dynamic_cast<OpenPanel *>( ui.Tab->currentWidget() ) )->updateMRL();
}
if( ui.advancedFrame->isVisible() )
{
ui.advancedFrame->hide();
- //setMinimumSize( 520, 460 );
if( size().isValid() )
resize( size().width(), size().height()
- ui.advancedFrame->height() );
else
{
ui.advancedFrame->show();
- //setMinimumSize( 520, 460 + ui.advancedFrame->height() );
if( size().isValid() )
resize( size().width(), size().height()
+ ui.advancedFrame->height() );
dynamic_cast<OpenPanel*>( ui.Tab->widget( i ) )->clear();
/* Clear the variables */
- mrl.clear();
- mainMRL.clear();
+ itemsMRL.clear();
+ optionsMRL.clear();
/* If in Select Mode, reject instead of hiding */
if( i_action_flag == SELECT ) reject();
void OpenDialog::finish( bool b_enqueue = false )
{
toggleVisible();
- mrl = ui.advancedLineInput->text();
- if( i_action_flag != SELECT )
+ if( i_action_flag == SELECT )
{
- QStringList tempMRL = SeparateEntries( mrl );
- for( size_t i = 0; i < tempMRL.size(); i++ )
- {
- bool b_start = !i && !b_enqueue;
- input_item_t *p_input;
+ accept();
+ return;
+ }
- p_input = input_ItemNew( p_intf, qtu( tempMRL[i] ), NULL );
+ /* Sort alphabetically */
+ itemsMRL.sort();
+
+ /* Go through the item list */
+ for( int i = 0; i < itemsMRL.size(); i++ )
+ {
+ bool b_start = !i && !b_enqueue;
+
+ input_item_t *p_input;
+ p_input = input_item_New( p_intf, qtu( itemsMRL[i] ), NULL );
+
+ /* Insert options only for the first element.
+ We don't know how to edit that anyway. */
+ if( i == 0 )
+ {
+ /* Take options from the UI, not from what we stored */
+ QStringList optionsList = ui.advancedLineInput->text().split( ":" );
/* Insert options */
- while( i + 1 < tempMRL.size() && tempMRL[i + 1].startsWith( ":" ) )
+ for( int j = 0; j < optionsList.size(); j++ )
{
- i++;
- input_ItemAddOption( p_input, qtu( tempMRL[i] ) );
+ QString qs = optionsList[j].trimmed();
+ if( !qs.isEmpty() )
+ {
+ input_item_AddOption( p_input, qtu( qs ), VLC_INPUT_OPTION_TRUSTED );
+ // msg_Err( p_intf, "Here %s", qtu( qs ));
+ }
}
+ }
- /* Switch between enqueuing and starting the item */
- /* FIXME: playlist_AddInput() can fail */
- playlist_AddInput( THEPL, p_input,
+ /* Switch between enqueuing and starting the item */
+ /* FIXME: playlist_AddInput() can fail */
+ playlist_AddInput( THEPL, p_input,
PLAYLIST_APPEND | ( b_start ? PLAYLIST_GO : PLAYLIST_PREPARSE ),
- PLAYLIST_END, true, pl_Unlocked );
- vlc_gc_decref( p_input );
- }
+ PLAYLIST_END, b_pl ? true : false, pl_Unlocked );
+ vlc_gc_decref( p_input );
+
+ /* Do not add the current MRL if playlist_AddInput fail */
+ RecentsMRL::getInstance( p_intf )->addRecent( itemsMRL[i] );
}
- else
- accept();
}
void OpenDialog::transcode()
void OpenDialog::stream( bool b_transcode_only )
{
- mrl = ui.advancedLineInput->text();
+ QString soutMRL = getMRL();
+ if( soutMRL.isEmpty() ) return;
toggleVisible();
- THEDP->streamingDialog( this, SeparateEntries( mrl )[0], b_transcode_only );
+
+ /* Dbg and send :D */
+ msg_Dbg( p_intf, "MRL passed to the Sout: %s", qtu( soutMRL ) );
+ THEDP->streamingDialog( this, soutMRL, b_transcode_only );
}
/* Update the MRL */
-void OpenDialog::updateMRL( QString tempMRL )
+void OpenDialog::updateMRL( QStringList item, QString tempMRL )
{
- mainMRL = tempMRL;
+ optionsMRL = tempMRL;
+ itemsMRL = item;
updateMRL();
}
void OpenDialog::updateMRL() {
- mrl = mainMRL;
+ QString mrl = optionsMRL;
if( ui.slaveCheckbox->isChecked() ) {
mrl += " :input-slave=" + ui.slaveText->text();
}
- int i_cache = config_GetInt( p_intf, qta( storedMethod ) );
+ int i_cache = config_GetInt( p_intf, qtu( storedMethod ) );
if( i_cache != ui.cacheSpinBox->value() ) {
mrl += QString( " :%1=%2" ).arg( storedMethod ).
arg( ui.cacheSpinBox->value() );
arg( ui.startTimeSpinBox->value() );
}
ui.advancedLineInput->setText( mrl );
+ ui.mrlLine->setText( itemsMRL.join( " " ) );
}
void OpenDialog::newCachingMethod( QString method )
{
if( method != storedMethod ) {
storedMethod = method;
- int i_value = config_GetInt( p_intf, qta( storedMethod ) );
+ int i_value = config_GetInt( p_intf, qtu( storedMethod ) );
ui.cacheSpinBox->setValue( i_value );
}
}
{
OpenDialog *od = new OpenDialog( this, p_intf, true, SELECT );
od->exec();
- ui.slaveText->setText( od->getMRL() );
+ ui.slaveText->setText( od->getMRL( false ) );
delete od;
}