author | llornkcor <llornkcor> | 2002-10-08 02:01:16 (UTC) |
---|---|---|
committer | llornkcor <llornkcor> | 2002-10-08 02:01:16 (UTC) |
commit | 40e9c78666e74221e06329bb07dfd66648b2727b (patch) (unidiff) | |
tree | afccf992024cc56a64d8495d80ce10478f946478 | |
parent | c43b5d600a7d1dcaadcba2cb047a60313b37f2f2 (diff) | |
download | opie-40e9c78666e74221e06329bb07dfd66648b2727b.zip opie-40e9c78666e74221e06329bb07dfd66648b2727b.tar.gz opie-40e9c78666e74221e06329bb07dfd66648b2727b.tar.bz2 |
fixed m3u handling
-rw-r--r-- | noncore/multimedia/opieplayer2/om3u.cpp | 16 | ||||
-rw-r--r-- | noncore/multimedia/opieplayer2/om3u.h | 2 | ||||
-rw-r--r-- | noncore/multimedia/opieplayer2/playlistwidget.cpp | 180 | ||||
-rw-r--r-- | noncore/multimedia/opieplayer2/playlistwidget.h | 1 |
4 files changed, 76 insertions, 123 deletions
diff --git a/noncore/multimedia/opieplayer2/om3u.cpp b/noncore/multimedia/opieplayer2/om3u.cpp index d378145..c947033 100644 --- a/noncore/multimedia/opieplayer2/om3u.cpp +++ b/noncore/multimedia/opieplayer2/om3u.cpp | |||
@@ -27,90 +27,90 @@ | |||
27 | Inc., 59 Temple Place - Suite 330, | 27 | Inc., 59 Temple Place - Suite 330, |
28 | Boston, MA 02111-1307, USA. | 28 | Boston, MA 02111-1307, USA. |
29 | 29 | ||
30 | */ | 30 | */ |
31 | 31 | ||
32 | #include "playlistwidget.h" | 32 | #include "playlistwidget.h" |
33 | #include "om3u.h" | 33 | #include "om3u.h" |
34 | 34 | ||
35 | #include <qpe/applnk.h> | 35 | #include <qpe/applnk.h> |
36 | #include <qpe/qpeapplication.h> | 36 | #include <qpe/qpeapplication.h> |
37 | #include <qpe/storage.h> | 37 | #include <qpe/storage.h> |
38 | #include <qpe/mimetype.h> | 38 | #include <qpe/mimetype.h> |
39 | #include <qpe/global.h> | 39 | #include <qpe/global.h> |
40 | #include <qpe/resource.h> | 40 | #include <qpe/resource.h> |
41 | 41 | ||
42 | #include <qdir.h> | 42 | #include <qdir.h> |
43 | #include <qregexp.h> | 43 | #include <qregexp.h> |
44 | #include <qstring.h> | 44 | #include <qstring.h> |
45 | #include <qtextstream.h> | 45 | #include <qtextstream.h> |
46 | #include <qstringlist.h> | 46 | #include <qstringlist.h> |
47 | #include <qcstring.h> | 47 | #include <qcstring.h> |
48 | 48 | ||
49 | //extern PlayListWidget *playList; | 49 | //extern PlayListWidget *playList; |
50 | 50 | ||
51 | Om3u::Om3u( const QString &filePath) | 51 | Om3u::Om3u( const QString &filePath, int mode) |
52 | : QStringList (){ | 52 | : QStringList (){ |
53 | //filePath is path name to m3u | 53 | //filePath is path name to m3u |
54 | //qDebug("<<<<<<<new m3u "+filePath); | 54 | //qDebug("<<<<<<<new m3u "+filePath); |
55 | f.setName(filePath); | 55 | f.setName(filePath); |
56 | if(f.exists()) | 56 | // if(f.exists()) |
57 | f.open( IO_ReadWrite ); | 57 | // f.open( IO_ReadWrite); |
58 | else | 58 | // else |
59 | f.open( IO_ReadWrite | IO_Truncate); | 59 | // f.open( IO_ReadWrite | IO_Truncate); |
60 | f.open(mode); | ||
61 | |||
60 | } | 62 | } |
61 | 63 | ||
62 | Om3u::~Om3u(){} | 64 | Om3u::~Om3u(){} |
63 | 65 | ||
64 | void Om3u::readM3u() { //it's m3u | 66 | void Om3u::readM3u() { //it's m3u |
65 | // qDebug("<<<<<<reading m3u "+f.name()); | 67 | // qDebug("<<<<<<reading m3u "+f.name()); |
66 | QTextStream t(&f); | 68 | QTextStream t(&f); |
67 | QString s; | 69 | QString s; |
68 | while ( !t.atEnd() ) { | 70 | while ( !t.atEnd() ) { |
69 | s=t.readLine(); | 71 | s=t.readLine(); |
70 | 72 | // qDebug(s); | |
71 | if( s.find( "#", 0, TRUE) == -1 ) { | 73 | if( s.find( "#", 0, TRUE) == -1 ) { |
72 | if( s.find( " ", 0, TRUE) == -1 ) { | ||
73 | if( s.left(2) == "E:" || s.left(2) == "P:" ) { | 74 | if( s.left(2) == "E:" || s.left(2) == "P:" ) { |
74 | s = s.right( s.length() -2 ); | 75 | s = s.right( s.length() -2 ); |
75 | QFileInfo f( s ); | 76 | QFileInfo f( s ); |
76 | QString name = f.baseName(); | 77 | QString name = f.baseName(); |
77 | name = name.right( name.length() - name.findRev( "\\", -1, TRUE ) -1 ); | 78 | name = name.right( name.length() - name.findRev( "\\", -1, TRUE ) -1 ); |
78 | s=s.replace( QRegExp( "\\" ), "/" ); | 79 | s=s.replace( QRegExp( "\\" ), "/" ); |
79 | append(s); | 80 | append(s); |
80 | // qDebug(s); | 81 | // qDebug(s); |
81 | } else { // is url | 82 | } else { // is url |
82 | s.replace( QRegExp( "%20" )," " ); | 83 | s.replace( QRegExp( "%20" )," " ); |
83 | QString name; | 84 | QString name; |
84 | if( name.left( 4 ) == "http" ) { | 85 | if( name.left( 4 ) == "http" ) { |
85 | name = s.right( s.length() - 7 ); | 86 | name = s.right( s.length() - 7 ); |
86 | } else { | 87 | } else { |
87 | name = s; | 88 | name = s; |
88 | } | 89 | } |
89 | append(name); | 90 | append(name); |
90 | // qDebug(name); | 91 | // qDebug(name); |
91 | } | 92 | } |
92 | } | ||
93 | } | 93 | } |
94 | } | 94 | } |
95 | } | 95 | } |
96 | 96 | ||
97 | void Om3u::readPls() { //it's a pls file | 97 | void Om3u::readPls() { //it's a pls file |
98 | QTextStream t( &f ); | 98 | QTextStream t( &f ); |
99 | QString s; | 99 | QString s; |
100 | while ( !t.atEnd() ) { | 100 | while ( !t.atEnd() ) { |
101 | s = t.readLine(); | 101 | s = t.readLine(); |
102 | if( s.left(4) == "File" ) { | 102 | if( s.left(4) == "File" ) { |
103 | s = s.right( s.length() - 6 ); | 103 | s = s.right( s.length() - 6 ); |
104 | s.replace( QRegExp( "%20" )," "); | 104 | s.replace( QRegExp( "%20" )," "); |
105 | // qDebug( "adding " + s + " to playlist" ); | 105 | // qDebug( "adding " + s + " to playlist" ); |
106 | // numberofentries=2 | 106 | // numberofentries=2 |
107 | // File1=http | 107 | // File1=http |
108 | // Title | 108 | // Title |
109 | // Length | 109 | // Length |
110 | // Version | 110 | // Version |
111 | // File2=http | 111 | // File2=http |
112 | s = s.replace( QRegExp( "\\" ), "/" ); | 112 | s = s.replace( QRegExp( "\\" ), "/" ); |
113 | QFileInfo f( s ); | 113 | QFileInfo f( s ); |
114 | QString name = f.baseName(); | 114 | QString name = f.baseName(); |
115 | if( name.left( 4 ) == "http" ) { | 115 | if( name.left( 4 ) == "http" ) { |
116 | name = s.right( s.length() - 7); | 116 | name = s.right( s.length() - 7); |
diff --git a/noncore/multimedia/opieplayer2/om3u.h b/noncore/multimedia/opieplayer2/om3u.h index 392980e..9c7cf9a 100644 --- a/noncore/multimedia/opieplayer2/om3u.h +++ b/noncore/multimedia/opieplayer2/om3u.h | |||
@@ -32,48 +32,48 @@ | |||
32 | #ifndef OM3U_H | 32 | #ifndef OM3U_H |
33 | #define OM3U_H | 33 | #define OM3U_H |
34 | 34 | ||
35 | #include "playlistwidget.h" | 35 | #include "playlistwidget.h" |
36 | 36 | ||
37 | #include <qpe/applnk.h> | 37 | #include <qpe/applnk.h> |
38 | #include <qpe/qpeapplication.h> | 38 | #include <qpe/qpeapplication.h> |
39 | #include <qpe/storage.h> | 39 | #include <qpe/storage.h> |
40 | #include <qpe/mimetype.h> | 40 | #include <qpe/mimetype.h> |
41 | #include <qpe/global.h> | 41 | #include <qpe/global.h> |
42 | #include <qpe/resource.h> | 42 | #include <qpe/resource.h> |
43 | 43 | ||
44 | #include <qdir.h> | 44 | #include <qdir.h> |
45 | #include <qregexp.h> | 45 | #include <qregexp.h> |
46 | #include <qstring.h> | 46 | #include <qstring.h> |
47 | #include <qtextstream.h> | 47 | #include <qtextstream.h> |
48 | #include <qstringlist.h> | 48 | #include <qstringlist.h> |
49 | #include <qcstring.h> | 49 | #include <qcstring.h> |
50 | #include <qfile.h> | 50 | #include <qfile.h> |
51 | 51 | ||
52 | 52 | ||
53 | class Om3u : public QStringList { | 53 | class Om3u : public QStringList { |
54 | // Q_OBJECT | 54 | // Q_OBJECT |
55 | public: | 55 | public: |
56 | Om3u( const QString &filePath); | 56 | Om3u( const QString &filePath, int mode); |
57 | ~Om3u(); | 57 | ~Om3u(); |
58 | void readM3u(); | 58 | void readM3u(); |
59 | void readPls(); | 59 | void readPls(); |
60 | void write(); | 60 | void write(); |
61 | void add(const QString &); | 61 | void add(const QString &); |
62 | void remove(const QString &); | 62 | void remove(const QString &); |
63 | void deleteFile(const QString &); | 63 | void deleteFile(const QString &); |
64 | void close(); | 64 | void close(); |
65 | 65 | ||
66 | public slots: | 66 | public slots: |
67 | 67 | ||
68 | protected: | 68 | protected: |
69 | 69 | ||
70 | private: | 70 | private: |
71 | QFile f; | 71 | QFile f; |
72 | private slots: | 72 | private slots: |
73 | 73 | ||
74 | 74 | ||
75 | }; | 75 | }; |
76 | 76 | ||
77 | #endif// M3U_H | 77 | #endif// M3U_H |
78 | 78 | ||
79 | 79 | ||
diff --git a/noncore/multimedia/opieplayer2/playlistwidget.cpp b/noncore/multimedia/opieplayer2/playlistwidget.cpp index 26c2896..b6525e1 100644 --- a/noncore/multimedia/opieplayer2/playlistwidget.cpp +++ b/noncore/multimedia/opieplayer2/playlistwidget.cpp | |||
@@ -127,295 +127,282 @@ PlayListWidget::PlayListWidget( QWidget* parent, const char* name, WFlags fl ) | |||
127 | this, SLOT( addToSelection( QListViewItem *) ) ); | 127 | this, SLOT( addToSelection( QListViewItem *) ) ); |
128 | connect( videoView, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int) ), | 128 | connect( videoView, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int) ), |
129 | this,SLOT( viewPressed( int, QListViewItem *, const QPoint&, int) ) ); | 129 | this,SLOT( viewPressed( int, QListViewItem *, const QPoint&, int) ) ); |
130 | connect( videoView, SIGNAL( returnPressed( QListViewItem *) ), | 130 | connect( videoView, SIGNAL( returnPressed( QListViewItem *) ), |
131 | this,SLOT( playIt( QListViewItem *) ) ); | 131 | this,SLOT( playIt( QListViewItem *) ) ); |
132 | connect( videoView, SIGNAL( doubleClicked( QListViewItem *) ), | 132 | connect( videoView, SIGNAL( doubleClicked( QListViewItem *) ), |
133 | this, SLOT( addToSelection( QListViewItem *) ) ); | 133 | this, SLOT( addToSelection( QListViewItem *) ) ); |
134 | connect( playLists, SIGNAL( fileSelected( const DocLnk &) ), | 134 | connect( playLists, SIGNAL( fileSelected( const DocLnk &) ), |
135 | this, SLOT( loadList( const DocLnk & ) ) ); | 135 | this, SLOT( loadList( const DocLnk & ) ) ); |
136 | connect( tabWidget, SIGNAL ( currentChanged(QWidget*) ), | 136 | connect( tabWidget, SIGNAL ( currentChanged(QWidget*) ), |
137 | this, SLOT( tabChanged( QWidget* ) ) ); | 137 | this, SLOT( tabChanged( QWidget* ) ) ); |
138 | connect( mediaPlayerState, SIGNAL( playingToggled( bool ) ), | 138 | connect( mediaPlayerState, SIGNAL( playingToggled( bool ) ), |
139 | d->tbPlay, SLOT( setOn( bool ) ) ); | 139 | d->tbPlay, SLOT( setOn( bool ) ) ); |
140 | connect( mediaPlayerState, SIGNAL( loopingToggled( bool ) ), | 140 | connect( mediaPlayerState, SIGNAL( loopingToggled( bool ) ), |
141 | d->tbLoop, SLOT( setOn( bool ) ) ); | 141 | d->tbLoop, SLOT( setOn( bool ) ) ); |
142 | connect( mediaPlayerState, SIGNAL( shuffledToggled( bool ) ), | 142 | connect( mediaPlayerState, SIGNAL( shuffledToggled( bool ) ), |
143 | d->tbShuffle, SLOT( setOn( bool ) ) ); | 143 | d->tbShuffle, SLOT( setOn( bool ) ) ); |
144 | connect( mediaPlayerState, SIGNAL( playlistToggled( bool ) ), | 144 | connect( mediaPlayerState, SIGNAL( playlistToggled( bool ) ), |
145 | this, SLOT( setPlaylist( bool ) ) ); | 145 | this, SLOT( setPlaylist( bool ) ) ); |
146 | connect( d->selectedFiles, SIGNAL( doubleClicked( QListViewItem *) ), | 146 | connect( d->selectedFiles, SIGNAL( doubleClicked( QListViewItem *) ), |
147 | this, SLOT( playIt( QListViewItem *) ) ); | 147 | this, SLOT( playIt( QListViewItem *) ) ); |
148 | connect ( gammaSlider, SIGNAL( valueChanged( int ) ), | 148 | connect ( gammaSlider, SIGNAL( valueChanged( int ) ), |
149 | mediaPlayerState, SLOT( setVideoGamma( int ) ) ); | 149 | mediaPlayerState, SLOT( setVideoGamma( int ) ) ); |
150 | 150 | ||
151 | // cfg.setGroup( "PlayList" ); | ||
152 | // if( cfg.readBoolEntry("newPlaylist") ){ | ||
153 | QString currentPlaylist = cfg.readEntry( "CurrentPlaylist", "" ); | ||
154 | loadList(DocLnk( currentPlaylist ) ); | ||
155 | setCaption( tr( "OpiePlayer: " ) + currentPlaylist ); | ||
156 | // } else { | ||
157 | // readConfig( cfg ); | ||
158 | |||
159 | // } | ||
160 | // see which skins are installed | 151 | // see which skins are installed |
161 | videoScan=FALSE; | 152 | videoScan=FALSE; |
162 | audioScan=FALSE; | 153 | audioScan=FALSE; |
163 | populateSkinsMenu(); | 154 | populateSkinsMenu(); |
164 | initializeStates(); | 155 | initializeStates(); |
156 | |||
157 | QString currentPlaylist = cfg.readEntry( "CurrentPlaylist", "" ); | ||
158 | loadList(DocLnk( currentPlaylist ) ); | ||
159 | setCaption( tr( "OpiePlayer: " ) + currentPlaylist ); | ||
165 | } | 160 | } |
166 | 161 | ||
167 | 162 | ||
168 | PlayListWidget::~PlayListWidget() { | 163 | PlayListWidget::~PlayListWidget() { |
169 | // WTF?!@?! | ||
170 | |||
171 | if ( d->current ) { | 164 | if ( d->current ) { |
172 | delete d->current; | 165 | delete d->current; |
173 | } | 166 | } |
174 | delete d; | 167 | delete d; |
175 | } | 168 | } |
176 | 169 | ||
177 | 170 | ||
178 | void PlayListWidget::initializeStates() { | 171 | void PlayListWidget::initializeStates() { |
179 | d->tbPlay->setOn( mediaPlayerState->playing() ); | 172 | d->tbPlay->setOn( mediaPlayerState->playing() ); |
180 | d->tbLoop->setOn( mediaPlayerState->looping() ); | 173 | d->tbLoop->setOn( mediaPlayerState->looping() ); |
181 | d->tbShuffle->setOn( mediaPlayerState->shuffled() ); | 174 | d->tbShuffle->setOn( mediaPlayerState->shuffled() ); |
182 | setPlaylist( true ); | 175 | setPlaylist( true ); |
183 | } | 176 | } |
184 | 177 | ||
185 | 178 | ||
186 | void PlayListWidget::readConfig( Config& cfg ) { | 179 | void PlayListWidget::readConfig( Config& cfg ) { |
187 | 180 | ||
188 | cfg.setGroup( "PlayList" ); | 181 | cfg.setGroup( "PlayList" ); |
189 | QString currentString = cfg.readEntry( "current", "" ); | 182 | QString currentString = cfg.readEntry( "current", "" ); |
190 | int noOfFiles = cfg.readNumEntry( "NumberOfFiles", 0 ); | 183 | int noOfFiles = cfg.readNumEntry( "NumberOfFiles", 0 ); |
191 | 184 | ||
192 | for ( int i = 0; i < noOfFiles; i++ ) { | 185 | for ( int i = 0; i < noOfFiles; i++ ) { |
193 | QString entryName; | 186 | QString entryName; |
194 | entryName.sprintf( "File%i", i + 1 ); | 187 | entryName.sprintf( "File%i", i + 1 ); |
195 | 188 | ||
196 | QString linkFile = cfg.readEntry( entryName ); | 189 | QString linkFile = cfg.readEntry( entryName ); |
197 | 190 | ||
198 | qDebug("reading "+linkFile); | 191 | qDebug("reading "+linkFile); |
199 | 192 | ||
200 | if( QFileInfo( linkFile ).exists() ) { | 193 | if( QFileInfo( linkFile ).exists() ) { |
201 | 194 | ||
202 | DocLnk lnk( linkFile ); | 195 | DocLnk lnk( linkFile ); |
203 | 196 | ||
204 | if ( QFileInfo( lnk.file() ).exists() || | 197 | if ( QFileInfo( lnk.file() ).exists() || |
205 | 198 | ||
206 | linkFile.find( "http" , 0, TRUE) != -1) { | 199 | linkFile.find( "http" , 0, TRUE) != -1) { |
207 | 200 | ||
208 | d->selectedFiles->addToSelection( lnk ); | 201 | d->selectedFiles->addToSelection( lnk ); |
209 | |||
210 | } | 202 | } |
211 | } | 203 | } |
212 | } | 204 | } |
213 | d->selectedFiles->setSelectedItem( currentString ); | 205 | d->selectedFiles->setSelectedItem( currentString ); |
214 | |||
215 | } | 206 | } |
216 | 207 | ||
217 | 208 | ||
218 | void PlayListWidget::writeConfig( Config& cfg ) const { | 209 | void PlayListWidget::writeConfig( Config& cfg ) const { |
219 | 210 | ||
220 | Config config( "OpiePlayer" ); | 211 | Config config( "OpiePlayer" ); |
221 | config.setGroup( "PlayList" ); | 212 | config.setGroup( "PlayList" ); |
222 | 213 | ||
223 | // if(config.readBoolEntry("newPlaylist")) { | 214 | // if(config.readBoolEntry("newPlaylist")) { |
224 | // new for testing | 215 | // new for testing |
225 | QString name, filename, list; | 216 | QString name, filename, list; |
226 | Om3u *m3uList; | 217 | Om3u *m3uList; |
227 | name = "default"; | 218 | name = "default"; |
228 | 219 | ||
229 | filename=QPEApplication::documentDir() + "/" + name+".m3u"; | 220 | filename=QPEApplication::documentDir() + "/" + name+".m3u"; |
230 | 221 | m3uList = new Om3u(filename, IO_ReadWrite); | |
231 | m3uList = new Om3u(filename); | ||
232 | |||
233 | d->selectedFiles->first(); | 222 | d->selectedFiles->first(); |
234 | do { | 223 | do { |
235 | m3uList->add( d->selectedFiles->current()->file()); | 224 | qDebug(d->selectedFiles->current()->file()); |
225 | m3uList->add( d->selectedFiles->current()->file() ); | ||
236 | } | 226 | } |
237 | while ( d->selectedFiles->next() ); | 227 | while ( d->selectedFiles->next() ); |
228 | // qDebug( list ); | ||
238 | 229 | ||
239 | qDebug( list ); | 230 | // m3uList->write(); |
240 | |||
241 | m3uList->write(); | ||
242 | m3uList->close(); | 231 | m3uList->close(); |
243 | if(m3uList) delete m3uList; | 232 | if(m3uList) delete m3uList; |
244 | 233 | ||
245 | DocLnk lnk; | 234 | DocLnk lnk; |
246 | lnk.setFile( filename); | 235 | lnk.setFile( filename); |
247 | lnk.setIcon("opieplayer2/playlist2"); | 236 | lnk.setIcon("opieplayer2/playlist2"); |
248 | lnk.setName( name); //sets file name | 237 | lnk.setName( name); //sets file name |
249 | 238 | ||
250 | qDebug("writing default playlist "+filename); | 239 | qDebug("writing default playlist "+filename); |
251 | 240 | ||
252 | config.writeEntry("CurrentPlaylist", filename); | 241 | config.writeEntry("CurrentPlaylist", filename); |
253 | // currentPlayList=filename; | 242 | // currentPlayList=filename; |
254 | |||
255 | if(!lnk.writeLink()) { | 243 | if(!lnk.writeLink()) { |
256 | qDebug("Writing doclink did not work"); | 244 | qDebug("Writing doclink did not work"); |
257 | } | 245 | } |
258 | |||
259 | // } else { | 246 | // } else { |
260 | 247 | ||
261 | // d->selectedFiles->writeCurrent( cfg ); | 248 | // d->selectedFiles->writeCurrent( cfg ); |
262 | // int noOfFiles = 0; | 249 | // int noOfFiles = 0; |
263 | // d->selectedFiles->first(); | 250 | // d->selectedFiles->first(); |
264 | 251 | ||
265 | // do { | 252 | // do { |
266 | // const DocLnk *lnk = d->selectedFiles->current(); | 253 | // const DocLnk *lnk = d->selectedFiles->current(); |
267 | 254 | ||
268 | // if ( lnk ) { | 255 | // if ( lnk ) { |
269 | 256 | ||
270 | // QString entryName; | 257 | // QString entryName; |
271 | // entryName.sprintf( "File%i", noOfFiles + 1 ); | 258 | // entryName.sprintf( "File%i", noOfFiles + 1 ); |
272 | 259 | ||
273 | // cfg.writeEntry( entryName, lnk->linkFile() ); | 260 | // cfg.writeEntry( entryName, lnk->linkFile() ); |
274 | // // if this link does exist, add it so we have the file | 261 | // // if this link does exist, add it so we have the file |
275 | // // next time... | 262 | // // next time... |
276 | 263 | ||
277 | // if ( !QFile::exists( lnk->linkFile() ) ) { | 264 | // if ( !QFile::exists( lnk->linkFile() ) ) { |
278 | // lnk->writeLink(); | 265 | // lnk->writeLink(); |
279 | // } | 266 | // } |
280 | // } | 267 | // } |
281 | // noOfFiles++; | 268 | // noOfFiles++; |
282 | // } | 269 | // } |
283 | // while ( d->selectedFiles->next() ); | 270 | // while ( d->selectedFiles->next() ); |
284 | // cfg.writeEntry("NumberOfFiles", noOfFiles ); | 271 | // cfg.writeEntry("NumberOfFiles", noOfFiles ); |
285 | // } | 272 | // } |
286 | } | 273 | } |
287 | 274 | ||
288 | |||
289 | void PlayListWidget::addToSelection( const DocLnk& lnk ) { | 275 | void PlayListWidget::addToSelection( const DocLnk& lnk ) { |
290 | d->setDocumentUsed = FALSE; | 276 | d->setDocumentUsed = FALSE; |
291 | if ( mediaPlayerState->playlist() ) { | 277 | if ( mediaPlayerState->playlist() ) { |
292 | if( QFileInfo( lnk.file() ).exists() || | 278 | if( QFileInfo( lnk.file() ).exists() || |
293 | lnk.file().left(4) == "http" ) | 279 | lnk.file().left(4) == "http" ) |
294 | d->selectedFiles->addToSelection( lnk ); | 280 | d->selectedFiles->addToSelection( lnk ); |
281 | writeCurrentM3u(); | ||
295 | } | 282 | } |
296 | else | 283 | else |
297 | mediaPlayerState->setPlaying( TRUE ); | 284 | mediaPlayerState->setPlaying( TRUE ); |
298 | } | 285 | } |
299 | 286 | ||
300 | 287 | ||
301 | void PlayListWidget::clearList() { | 288 | void PlayListWidget::clearList() { |
302 | while ( first() ) { | 289 | while ( first() ) { |
303 | d->selectedFiles->removeSelected(); | 290 | d->selectedFiles->removeSelected(); |
304 | } | 291 | } |
305 | } | 292 | } |
306 | 293 | ||
307 | |||
308 | void PlayListWidget::viewPressed( int mouse, QListViewItem *, const QPoint& , int) { | 294 | void PlayListWidget::viewPressed( int mouse, QListViewItem *, const QPoint& , int) { |
309 | switch (mouse) { | 295 | switch (mouse) { |
310 | case 1: | 296 | case 1: |
311 | break; | 297 | break; |
312 | case 2: | 298 | case 2: |
313 | { | 299 | { |
314 | QPopupMenu m; | 300 | QPopupMenu m; |
315 | m.insertItem( tr( "Play Selected" ), this, SLOT( playSelected() )); | 301 | m.insertItem( tr( "Play Selected" ), this, SLOT( playSelected() )); |
316 | m.insertItem( tr( "Add to Playlist" ), this, SLOT( addSelected() )); | 302 | m.insertItem( tr( "Add to Playlist" ), this, SLOT( addSelected() )); |
317 | m.exec( QCursor::pos() ); | 303 | m.exec( QCursor::pos() ); |
318 | } | 304 | } |
319 | break; | 305 | break; |
320 | } | 306 | } |
321 | } | 307 | } |
322 | 308 | ||
323 | 309 | ||
324 | void PlayListWidget::playlistViewPressed( int mouse, QListViewItem *, const QPoint& , int ) { | 310 | void PlayListWidget::playlistViewPressed( int mouse, QListViewItem *, const QPoint& , int ) { |
325 | switch (mouse) { | 311 | switch (mouse) { |
326 | case 1: | 312 | case 1: |
327 | break; | 313 | break; |
328 | case 2: | 314 | case 2: |
329 | { | 315 | { |
330 | QPopupMenu m; | 316 | QPopupMenu m; |
331 | m.insertItem( tr( "Play" ), this, SLOT( playSelected() )); | 317 | m.insertItem( tr( "Play" ), this, SLOT( playSelected() )); |
332 | m.insertItem( tr( "Remove" ), this, SLOT( removeSelected() )); | 318 | m.insertItem( tr( "Remove" ), this, SLOT( removeSelected() )); |
333 | m.exec( QCursor::pos() ); | 319 | m.exec( QCursor::pos() ); |
334 | } | 320 | } |
335 | break; | 321 | break; |
336 | } | 322 | } |
337 | } | 323 | } |
338 | 324 | ||
339 | 325 | ||
340 | void PlayListWidget::addAllToList() { | 326 | void PlayListWidget::addAllToList() { |
341 | DocLnkSet filesAll; | 327 | DocLnkSet filesAll; |
342 | Global::findDocuments(&filesAll, "video/*;audio/*"); | 328 | Global::findDocuments(&filesAll, "video/*;audio/*"); |
343 | QListIterator<DocLnk> Adit( filesAll.children() ); | 329 | QListIterator<DocLnk> Adit( filesAll.children() ); |
344 | for ( ; Adit.current(); ++Adit ) { | 330 | for ( ; Adit.current(); ++Adit ) { |
345 | if( QFileInfo( Adit.current()->file() ).exists() ) { | 331 | if( QFileInfo( Adit.current()->file() ).exists() ) { |
346 | d->selectedFiles->addToSelection( **Adit ); | 332 | d->selectedFiles->addToSelection( **Adit ); |
347 | } | 333 | } |
348 | } | 334 | } |
335 | writeCurrentM3u(); | ||
349 | } | 336 | } |
350 | 337 | ||
351 | 338 | ||
352 | void PlayListWidget::addAllMusicToList() { | 339 | void PlayListWidget::addAllMusicToList() { |
353 | QListIterator<DocLnk> dit( files.children() ); | 340 | QListIterator<DocLnk> dit( files.children() ); |
354 | for ( ; dit.current(); ++dit ) { | 341 | for ( ; dit.current(); ++dit ) { |
355 | if( QFileInfo(dit.current()->file() ).exists() ) { | 342 | if( QFileInfo(dit.current()->file() ).exists() ) { |
356 | d->selectedFiles->addToSelection( **dit ); | 343 | d->selectedFiles->addToSelection( **dit ); |
357 | } | 344 | } |
358 | } | 345 | } |
346 | writeCurrentM3u(); | ||
359 | } | 347 | } |
360 | 348 | ||
361 | 349 | ||
362 | void PlayListWidget::addAllVideoToList() { | 350 | void PlayListWidget::addAllVideoToList() { |
363 | QListIterator<DocLnk> dit( vFiles.children() ); | 351 | QListIterator<DocLnk> dit( vFiles.children() ); |
364 | for ( ; dit.current(); ++dit ) { | 352 | for ( ; dit.current(); ++dit ) { |
365 | if( QFileInfo( dit.current()->file() ).exists() ) { | 353 | if( QFileInfo( dit.current()->file() ).exists() ) { |
366 | d->selectedFiles->addToSelection( **dit ); | 354 | d->selectedFiles->addToSelection( **dit ); |
367 | } | 355 | } |
368 | } | 356 | } |
357 | writeCurrentM3u(); | ||
369 | } | 358 | } |
370 | 359 | ||
371 | 360 | ||
372 | void PlayListWidget::setDocument( const QString& fileref ) { | 361 | void PlayListWidget::setDocument( const QString& fileref ) { |
373 | //qDebug( fileref ); | 362 | //qDebug( fileref ); |
374 | fromSetDocument = TRUE; | 363 | fromSetDocument = TRUE; |
375 | if ( fileref.isNull() ) { | 364 | if ( fileref.isNull() ) { |
376 | QMessageBox::critical( 0, tr( "Invalid File" ), | 365 | QMessageBox::critical( 0, tr( "Invalid File" ), |
377 | tr( "There was a problem in getting the file." ) ); | 366 | tr( "There was a problem in getting the file." ) ); |
378 | return; | 367 | return; |
379 | } | 368 | } |
380 | 369 | ||
381 | if( fileref.find( "m3u", 0, TRUE) != -1 ) { //is m3u | 370 | if( fileref.find( "m3u", 0, TRUE) != -1 ) { //is m3u |
382 | readm3u( fileref ); | 371 | readm3u( fileref ); |
383 | } else if( fileref.find( "pls", 0, TRUE) != -1 ) { //is pls | 372 | } else if( fileref.find( "pls", 0, TRUE) != -1 ) { //is pls |
384 | readPls( fileref ); | 373 | readPls( fileref ); |
385 | } else if( fileref.find( "playlist", 0, TRUE) != -1 ) {//is playlist | 374 | }// else if( fileref.find( "playlist", 0, TRUE) != -1 ) {//is playlist |
386 | clearList(); | 375 | // clearList(); |
387 | loadList( DocLnk( fileref ) ); | 376 | // loadList( DocLnk( fileref ) ); |
388 | d->selectedFiles->first(); | 377 | // d->selectedFiles->first(); |
389 | } else { | 378 | // } |
379 | else { | ||
390 | clearList(); | 380 | clearList(); |
391 | addToSelection( DocLnk( fileref ) ); | 381 | addToSelection( DocLnk( fileref ) ); |
392 | d->setDocumentUsed = TRUE; | 382 | d->setDocumentUsed = TRUE; |
393 | mediaPlayerState->setPlaying( FALSE ); | 383 | mediaPlayerState->setPlaying( FALSE ); |
394 | // qApp->processEvents(); | ||
395 | mediaPlayerState->setPlaying( TRUE ); | 384 | mediaPlayerState->setPlaying( TRUE ); |
396 | // qApp->processEvents(); | ||
397 | setCaption( tr("OpiePlayer") ); | ||
398 | } | 385 | } |
399 | } | 386 | } |
400 | 387 | ||
401 | 388 | ||
402 | void PlayListWidget::useSelectedDocument() { | 389 | void PlayListWidget::useSelectedDocument() { |
403 | d->setDocumentUsed = FALSE; | 390 | d->setDocumentUsed = FALSE; |
404 | } | 391 | } |
405 | 392 | ||
406 | 393 | ||
407 | const DocLnk *PlayListWidget::current() { // this is fugly | 394 | const DocLnk *PlayListWidget::current() { // this is fugly |
408 | switch ( whichList() ) { | 395 | switch ( whichList() ) { |
409 | case 0: //playlist | 396 | case 0: //playlist |
410 | { | 397 | { |
411 | // qDebug("playlist"); | 398 | // qDebug("playlist"); |
412 | if ( mediaPlayerState->playlist() ) { | 399 | if ( mediaPlayerState->playlist() ) { |
413 | return d->selectedFiles->current(); | 400 | return d->selectedFiles->current(); |
414 | } else if ( d->setDocumentUsed && d->current ) { | 401 | } else if ( d->setDocumentUsed && d->current ) { |
415 | return d->current; | 402 | return d->current; |
416 | } else { | 403 | } else { |
417 | return &(d->files->selectedDocument()); | 404 | return &(d->files->selectedDocument()); |
418 | } | 405 | } |
419 | } | 406 | } |
420 | break; | 407 | break; |
421 | }; | 408 | }; |
@@ -470,213 +457,165 @@ bool PlayListWidget::next() { | |||
470 | } | 457 | } |
471 | } else { | 458 | } else { |
472 | return mediaPlayerState->looping(); | 459 | return mediaPlayerState->looping(); |
473 | } | 460 | } |
474 | } | 461 | } |
475 | 462 | ||
476 | 463 | ||
477 | bool PlayListWidget::first() { | 464 | bool PlayListWidget::first() { |
478 | if ( mediaPlayerState->playlist() ) | 465 | if ( mediaPlayerState->playlist() ) |
479 | return d->selectedFiles->first(); | 466 | return d->selectedFiles->first(); |
480 | else | 467 | else |
481 | return mediaPlayerState->looping(); | 468 | return mediaPlayerState->looping(); |
482 | } | 469 | } |
483 | 470 | ||
484 | 471 | ||
485 | bool PlayListWidget::last() { | 472 | bool PlayListWidget::last() { |
486 | if ( mediaPlayerState->playlist() ) | 473 | if ( mediaPlayerState->playlist() ) |
487 | return d->selectedFiles->last(); | 474 | return d->selectedFiles->last(); |
488 | else | 475 | else |
489 | return mediaPlayerState->looping(); | 476 | return mediaPlayerState->looping(); |
490 | } | 477 | } |
491 | 478 | ||
492 | 479 | ||
493 | void PlayListWidget::saveList() { | 480 | void PlayListWidget::saveList() { |
494 | // Config config( "OpiePlayer" ); | 481 | writem3u(); |
495 | // config.setGroup( "PlayList" ); | ||
496 | |||
497 | // if(config.readBoolEntry("newPlaylist") ){ | ||
498 | writem3u(); | ||
499 | |||
500 | // } else { | ||
501 | |||
502 | // QString filename; | ||
503 | // InputDialog *fileDlg = 0l; | ||
504 | // fileDlg = new InputDialog(this,tr("Save Playlist"),TRUE, 0); | ||
505 | // fileDlg->exec(); | ||
506 | // if( fileDlg->result() == 1 ) { | ||
507 | // if ( d->current ) | ||
508 | // delete d->current; | ||
509 | // filename = fileDlg->text();//+".playlist"; | ||
510 | // // qDebug("saving playlist "+filename+".playlist"); | ||
511 | |||
512 | // Config cfg( filename +".playlist"); | ||
513 | // writeConfig( cfg ); | ||
514 | |||
515 | // DocLnk lnk; | ||
516 | // lnk.setFile(QDir::homeDirPath()+"/Settings/"+filename+".playlist.conf"); | ||
517 | // //sets File property | ||
518 | // lnk.setType("playlist/plain"); | ||
519 | // lnk.setIcon("opieplayer2/playlist2"); | ||
520 | // lnk.setName( filename); //sets file name | ||
521 | // // qDebug(filename); | ||
522 | // if(!lnk.writeLink()) { | ||
523 | // qDebug("Writing doclink did not work"); | ||
524 | // } | ||
525 | // } | ||
526 | |||
527 | // config.writeEntry("CurrentPlaylist",filename); | ||
528 | // setCaption(tr("OpiePlayer: ")+filename); | ||
529 | // d->selectedFiles->first(); | ||
530 | // if(fileDlg) { | ||
531 | // delete fileDlg; | ||
532 | // } | ||
533 | // } | ||
534 | } | 482 | } |
535 | 483 | ||
536 | 484 | ||
537 | void PlayListWidget::loadList( const DocLnk & lnk) { | 485 | void PlayListWidget::loadList( const DocLnk & lnk) { |
538 | QString name = lnk.name(); | 486 | QString name = lnk.name(); |
539 | qDebug("currentList is "+name); | 487 | // qDebug("<<<<<<<<<<<<<<<<<<<<<<<<currentList is "+name); |
540 | 488 | ||
541 | if( name.length()>0) { | 489 | if( name.length()>0) { |
542 | setCaption("OpiePlayer: "+name); | 490 | setCaption("OpiePlayer: "+name); |
543 | qDebug("<<<<<<<<<<<<load list "+ lnk.file()); | 491 | qDebug("<<<<<<<<<<<<load list "+ lnk.file()); |
544 | clearList(); | 492 | clearList(); |
545 | |||
546 | // if(name.right(3) == "m3u") { | ||
547 | |||
548 | readm3u(lnk.file()); | 493 | readm3u(lnk.file()); |
549 | // } else { | ||
550 | // / Config cfg( name+".playlist"); | ||
551 | // readConfig(cfg); | ||
552 | |||
553 | tabWidget->setCurrentPage(0); | 494 | tabWidget->setCurrentPage(0); |
554 | |||
555 | Config config( "OpiePlayer" ); | ||
556 | config.setGroup( "PlayList" ); | ||
557 | config.writeEntry("CurrentPlaylist", lnk.file()); | ||
558 | // // d->selectedFiles->first(); | ||
559 | // } | ||
560 | } | 495 | } |
561 | } | 496 | } |
562 | 497 | ||
563 | 498 | ||
564 | void PlayListWidget::setPlaylist( bool shown ) { | 499 | void PlayListWidget::setPlaylist( bool shown ) { |
565 | if ( shown ) { | 500 | if ( shown ) { |
566 | d->playListFrame->show(); | 501 | d->playListFrame->show(); |
567 | } else { | 502 | } else { |
568 | d->playListFrame->hide(); | 503 | d->playListFrame->hide(); |
569 | } | 504 | } |
570 | } | 505 | } |
571 | 506 | ||
572 | 507 | ||
573 | void PlayListWidget::addSelected() { | 508 | void PlayListWidget::addSelected() { |
574 | 509 | ||
575 | Config cfg( "OpiePlayer" ); | ||
576 | cfg.setGroup("PlayList"); | ||
577 | QString currentPlaylist = cfg.readEntry("CurrentPlaylist",""); | ||
578 | // int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 ); | ||
579 | |||
580 | switch (whichList()) { | 510 | switch (whichList()) { |
581 | case 0: //playlist | 511 | case 0: //playlist |
582 | break; | 512 | break; |
583 | case 1: { //audio | 513 | case 1: { //audio |
584 | QListViewItemIterator it( audioView ); | 514 | QListViewItemIterator it( audioView ); |
585 | // iterate through all items of the listview | 515 | // iterate through all items of the listview |
586 | for ( ; it.current(); ++it ) { | 516 | for ( ; it.current(); ++it ) { |
587 | if ( it.current()->isSelected() ) { | 517 | if ( it.current()->isSelected() ) { |
588 | QListIterator<DocLnk> dit( files.children() ); | 518 | QListIterator<DocLnk> dit( files.children() ); |
589 | for ( ; dit.current(); ++dit ) { | 519 | for ( ; dit.current(); ++dit ) { |
590 | if( dit.current()->name() == it.current()->text(0) ) { | 520 | if( dit.current()->name() == it.current()->text(0) ) { |
591 | if(QFileInfo( dit.current()->file()).exists()) | 521 | if( QFileInfo( dit.current()->file()).exists()) { |
592 | d->selectedFiles->addToSelection( **dit ); | 522 | d->selectedFiles->addToSelection( **dit ); |
523 | audioView->setSelected( it.current(),FALSE); | ||
524 | } | ||
593 | } | 525 | } |
594 | } | 526 | } |
595 | audioView->setSelected( it.current(),FALSE); | ||
596 | } | 527 | } |
597 | } | 528 | } |
598 | tabWidget->setCurrentPage(0); | 529 | tabWidget->setCurrentPage(0); |
530 | writeCurrentM3u(); | ||
599 | } | 531 | } |
600 | break; | 532 | break; |
601 | case 2: { // video | 533 | case 2: { // video |
602 | QListViewItemIterator it( videoView ); | 534 | QListViewItemIterator it( videoView ); |
603 | // iterate through all items of the listview | 535 | // iterate through all items of the listview |
604 | for ( ; it.current(); ++it ) { | 536 | for ( ; it.current(); ++it ) { |
605 | if ( it.current()->isSelected() ) { | 537 | if ( it.current()->isSelected() ) { |
606 | QListIterator<DocLnk> dit( vFiles.children() ); | 538 | QListIterator<DocLnk> dit( vFiles.children() ); |
607 | for ( ; dit.current(); ++dit ) { | 539 | for ( ; dit.current(); ++dit ) { |
608 | if( dit.current()->name() == it.current()->text(0) ) { | 540 | if( dit.current()->name() == it.current()->text(0) ) { |
609 | if(QFileInfo( dit.current()->file()).exists()) | 541 | if(QFileInfo( dit.current()->file()).exists()) { |
610 | d->selectedFiles->addToSelection( **dit ); | 542 | d->selectedFiles->addToSelection( **dit ); |
543 | videoView->setSelected( it.current(),FALSE); | ||
544 | } | ||
611 | } | 545 | } |
612 | } | 546 | } |
613 | videoView->setSelected( it.current(),FALSE); | ||
614 | } | 547 | } |
615 | } | 548 | } |
616 | tabWidget->setCurrentPage(0); | 549 | tabWidget->setCurrentPage(0); |
550 | writeCurrentM3u(); | ||
617 | } | 551 | } |
618 | break; | 552 | break; |
619 | }; | 553 | }; |
620 | } | 554 | } |
621 | 555 | ||
622 | 556 | ||
623 | void PlayListWidget::removeSelected() { | 557 | void PlayListWidget::removeSelected() { |
624 | d->selectedFiles->removeSelected( ); | 558 | d->selectedFiles->removeSelected( ); |
625 | } | 559 | } |
626 | 560 | ||
627 | 561 | ||
628 | void PlayListWidget::playIt( QListViewItem *it) { | 562 | void PlayListWidget::playIt( QListViewItem *it) { |
629 | if(!it) return; | 563 | if(!it) return; |
630 | mediaPlayerState->setPlaying(FALSE); | 564 | mediaPlayerState->setPlaying(FALSE); |
631 | mediaPlayerState->setPlaying(TRUE); | 565 | mediaPlayerState->setPlaying(TRUE); |
632 | d->selectedFiles->unSelect(); | 566 | d->selectedFiles->unSelect(); |
633 | } | 567 | } |
634 | 568 | ||
635 | 569 | ||
636 | void PlayListWidget::addToSelection( QListViewItem *it) { | 570 | void PlayListWidget::addToSelection( QListViewItem *it) { |
637 | d->setDocumentUsed = FALSE; | 571 | d->setDocumentUsed = FALSE; |
638 | 572 | ||
639 | if(it) { | 573 | if(it) { |
640 | switch ( whichList()) { | 574 | switch ( whichList()) { |
641 | case 1: { | 575 | case 1: { |
642 | QListIterator<DocLnk> dit( files.children() ); | 576 | QListIterator<DocLnk> dit( files.children() ); |
643 | for ( ; dit.current(); ++dit ) { | 577 | for ( ; dit.current(); ++dit ) { |
644 | if( dit.current()->name() == it->text(0)) { | 578 | if( dit.current()->name() == it->text(0)) { |
645 | if(QFileInfo( dit.current()->file()).exists()) | 579 | if(QFileInfo( dit.current()->file()).exists()) |
646 | d->selectedFiles->addToSelection( **dit ); | 580 | d->selectedFiles->addToSelection( **dit ); |
647 | } | 581 | } |
648 | } | 582 | } |
583 | writeCurrentM3u(); | ||
584 | |||
649 | } | 585 | } |
586 | |||
650 | break; | 587 | break; |
651 | case 2: { | 588 | case 2: { |
652 | QListIterator<DocLnk> dit( vFiles.children() ); | 589 | QListIterator<DocLnk> dit( vFiles.children() ); |
653 | for ( ; dit.current(); ++dit ) { | 590 | for ( ; dit.current(); ++dit ) { |
654 | if( dit.current()->name() == it->text(0)) { | 591 | if( dit.current()->name() == it->text(0)) { |
655 | if( QFileInfo( dit.current()->file()).exists() ) | 592 | if( QFileInfo( dit.current()->file()).exists() ) |
656 | d->selectedFiles->addToSelection( **dit ); | 593 | d->selectedFiles->addToSelection( **dit ); |
657 | } | 594 | } |
658 | } | 595 | } |
596 | writeCurrentM3u(); | ||
597 | |||
659 | } | 598 | } |
660 | break; | 599 | break; |
661 | case 0: | 600 | case 0: |
662 | break; | 601 | break; |
663 | }; | 602 | }; |
664 | tabWidget->setCurrentPage(0); | 603 | tabWidget->setCurrentPage(0); |
665 | } | 604 | } |
666 | } | 605 | } |
667 | 606 | ||
668 | 607 | ||
669 | void PlayListWidget::tabChanged(QWidget *) { | 608 | void PlayListWidget::tabChanged(QWidget *) { |
670 | 609 | ||
671 | switch ( whichList()) { | 610 | switch ( whichList()) { |
672 | case 0: | 611 | case 0: |
673 | { | 612 | { |
674 | if( !tbDeletePlaylist->isHidden() ) { | 613 | if( !tbDeletePlaylist->isHidden() ) { |
675 | tbDeletePlaylist->hide(); | 614 | tbDeletePlaylist->hide(); |
676 | } | 615 | } |
677 | d->tbRemoveFromList->setEnabled(TRUE); | 616 | d->tbRemoveFromList->setEnabled(TRUE); |
678 | d->tbAddToList->setEnabled(FALSE); | 617 | d->tbAddToList->setEnabled(FALSE); |
679 | } | 618 | } |
680 | break; | 619 | break; |
681 | case 1: | 620 | case 1: |
682 | { | 621 | { |
@@ -829,214 +768,227 @@ void PlayListWidget::populateVideoView() { | |||
829 | storage, Vdit.current()->file()); | 768 | storage, Vdit.current()->file()); |
830 | newItem->setPixmap(0, Resource::loadPixmap( "opieplayer2/videofile" ) ); | 769 | newItem->setPixmap(0, Resource::loadPixmap( "opieplayer2/videofile" ) ); |
831 | } | 770 | } |
832 | } | 771 | } |
833 | } | 772 | } |
834 | 773 | ||
835 | 774 | ||
836 | void PlayListWidget::openFile() { | 775 | void PlayListWidget::openFile() { |
837 | QString filename, name; | 776 | QString filename, name; |
838 | InputDialog *fileDlg; | 777 | InputDialog *fileDlg; |
839 | fileDlg = new InputDialog(this,tr("Open file or URL"),TRUE, 0); | 778 | fileDlg = new InputDialog(this,tr("Open file or URL"),TRUE, 0); |
840 | fileDlg->exec(); | 779 | fileDlg->exec(); |
841 | if( fileDlg->result() == 1 ) { | 780 | if( fileDlg->result() == 1 ) { |
842 | filename = fileDlg->text(); | 781 | filename = fileDlg->text(); |
843 | 782 | ||
844 | qDebug( "Selected filename is " + filename ); | 783 | qDebug( "Selected filename is " + filename ); |
845 | 784 | ||
846 | if(filename.left(4) == "http") { //if http, lets write a new m3u | 785 | if(filename.left(4) == "http") { //if http, lets write a new m3u |
847 | Om3u *m3uList; | 786 | Om3u *m3uList; |
848 | DocLnk lnk; | 787 | DocLnk lnk; |
849 | QString m3uFile, m3uFilePath; | 788 | QString m3uFile, m3uFilePath; |
850 | 789 | ||
851 | if(filename.find(":",8,TRUE) != -1) { //found a port | 790 | if(filename.find(":",8,TRUE) != -1) { //found a port |
852 | m3uFile = filename.left( filename.find( ":",8,TRUE)); | 791 | m3uFile = filename.left( filename.find( ":",8,TRUE)); |
853 | |||
854 | m3uFile = m3uFile.right( 7); | 792 | m3uFile = m3uFile.right( 7); |
855 | |||
856 | } else if(filename.left(4) == "http"){ | 793 | } else if(filename.left(4) == "http"){ |
857 | |||
858 | m3uFile=filename; | 794 | m3uFile=filename; |
859 | m3uFile = m3uFile.right( m3uFile.length() - 7); | 795 | m3uFile = m3uFile.right( m3uFile.length() - 7); |
860 | |||
861 | } else{ | 796 | } else{ |
862 | m3uFile=filename; | 797 | m3uFile=filename; |
863 | } | 798 | } |
864 | |||
865 | // qDebug( m3uFile); | 799 | // qDebug( m3uFile); |
866 | 800 | ||
867 | //this is where this new m3u is going to live at | 801 | //this is where this new m3u is going to live at |
868 | m3uFilePath = QDir::homeDirPath() + "/" + m3uFile + ".m3u"; | 802 | m3uFilePath = QDir::homeDirPath() + "/" + m3uFile + ".m3u"; |
869 | // m3uFile += ".m3u"; | 803 | // m3uFile += ".m3u"; |
870 | m3uList = new Om3u( m3uFile+".m3u"); | 804 | m3uList = new Om3u( m3uFile+".m3u", IO_ReadWrite ); |
871 | |||
872 | m3uList->add( filename); | 805 | m3uList->add( filename); |
873 | m3uList->write(); | 806 | m3uList->write(); |
874 | if(m3uList) delete m3uList; | 807 | if(m3uList) delete m3uList; |
875 | |||
876 | // qDebug( m3uFile); | 808 | // qDebug( m3uFile); |
877 | lnk.setName( filename ); //sets file name | 809 | lnk.setName( filename ); //sets file name |
878 | lnk.setFile( m3uFilePath ); //sets File property | 810 | lnk.setFile( m3uFilePath ); //sets File property |
879 | lnk.setType( MimeType( QFile::encodeName(m3uFilePath) ).id() ); | 811 | lnk.setType( MimeType( QFile::encodeName(m3uFilePath) ).id() ); |
880 | 812 | ||
881 | lnk.setExec( "opieplayer2" ); | 813 | lnk.setExec( "opieplayer2" ); |
882 | lnk.setIcon("opieplayer2/playlist2"); | 814 | lnk.setIcon("opieplayer2/playlist2"); |
883 | 815 | ||
884 | if( !lnk.writeLink() ) { | 816 | if( !lnk.writeLink() ) { |
885 | qDebug( "Writing doclink did not work" ); | 817 | qDebug( "Writing doclink did not work" ); |
886 | } | 818 | } |
887 | d->selectedFiles->addToSelection( lnk ); | 819 | d->selectedFiles->addToSelection( lnk ); |
888 | 820 | ||
889 | } | 821 | } |
890 | else if( filename.right( 3 ) == "m3u" ) { | 822 | else if( filename.right( 3 ) == "m3u" ) { |
891 | readm3u( filename ); | 823 | readm3u( filename ); |
892 | 824 | ||
893 | } else if( filename.right(3) == "pls" ) { | 825 | } else if( filename.right(3) == "pls" ) { |
894 | readPls( filename ); | 826 | readPls( filename ); |
895 | } | 827 | } |
896 | } | 828 | } |
897 | if( fileDlg ) { | 829 | if( fileDlg ) { |
898 | delete fileDlg; | 830 | delete fileDlg; |
899 | } | 831 | } |
900 | } | 832 | } |
901 | 833 | ||
902 | /* | 834 | /* |
903 | reads m3u and adds files/urls to playlist */ | 835 | reads m3u and adds files/urls to playlist */ |
904 | void PlayListWidget::readm3u( const QString &filename ) { | 836 | void PlayListWidget::readm3u( const QString &filename ) { |
905 | qDebug( "read m3u filename " + filename ); | 837 | qDebug( "read m3u filename " + filename ); |
906 | 838 | ||
907 | Om3u *m3uList; | 839 | Om3u *m3uList; |
908 | QString s, name; | 840 | QString s, name; |
909 | m3uList = new Om3u( filename); | 841 | m3uList = new Om3u( filename, IO_ReadOnly ); |
910 | m3uList->readM3u(); | 842 | m3uList->readM3u(); |
911 | DocLnk lnk; | 843 | DocLnk lnk; |
912 | for ( QStringList::ConstIterator it = m3uList->begin(); it != m3uList->end(); ++it ) { | 844 | for ( QStringList::ConstIterator it = m3uList->begin(); it != m3uList->end(); ++it ) { |
913 | s = *it; | 845 | s = *it; |
914 | s.replace( QRegExp( "%20" )," " ); | 846 | s.replace( QRegExp( "%20" )," " ); |
915 | qDebug("reading "+ s); | 847 | // qDebug("reading "+ s); |
916 | 848 | ||
917 | if( QFileInfo( s ).exists() ) { | 849 | if( QFileInfo( s ).exists() ) { |
918 | lnk.setName( QFileInfo(s).baseName()); | 850 | lnk.setName( QFileInfo(s).baseName()); |
919 | qDebug("set link "+s); | 851 | // qDebug("set link "+s); |
920 | if(s.at(s.length()-4) == '.') //if regular file | 852 | if(s.at(s.length()-4) == '.') //if regular file |
921 | lnk.setFile( s); | 853 | lnk.setFile( s); |
922 | else | 854 | else |
923 | lnk.setFile( s+"/"); //if url with no extension | 855 | lnk.setFile( s+"/"); //if url with no extension |
924 | 856 | ||
925 | d->selectedFiles->addToSelection( lnk ); | 857 | d->selectedFiles->addToSelection( lnk ); |
926 | } | 858 | } |
927 | } | 859 | } |
928 | Config config( "OpiePlayer" ); | 860 | Config config( "OpiePlayer" ); |
929 | config.setGroup( "PlayList" ); | 861 | config.setGroup( "PlayList" ); |
930 | 862 | ||
931 | config.writeEntry("CurrentPlaylist",filename); | 863 | config.writeEntry("CurrentPlaylist",filename); |
864 | config.write(); | ||
932 | currentPlayList=filename; | 865 | currentPlayList=filename; |
933 | 866 | ||
934 | m3uList->close(); | 867 | m3uList->close(); |
935 | if(m3uList) delete m3uList; | 868 | if(m3uList) delete m3uList; |
936 | 869 | ||
937 | d->selectedFiles->setSelectedItem( s); | 870 | d->selectedFiles->setSelectedItem( s); |
938 | setCaption(tr("OpiePlayer: ")+ QFileInfo(s).baseName()); | 871 | setCaption(tr("OpiePlayer: ")+ filename); |
939 | 872 | ||
940 | } | 873 | } |
941 | 874 | ||
942 | /* | 875 | /* |
943 | reads pls and adds files/urls to playlist */ | 876 | reads pls and adds files/urls to playlist */ |
944 | void PlayListWidget::readPls( const QString &filename ) { | 877 | void PlayListWidget::readPls( const QString &filename ) { |
945 | 878 | ||
946 | qDebug( "pls filename is " + filename ); | 879 | qDebug( "pls filename is " + filename ); |
947 | Om3u *m3uList; | 880 | Om3u *m3uList; |
948 | QString s, name; | 881 | QString s, name; |
949 | m3uList = new Om3u( filename); | 882 | m3uList = new Om3u( filename, IO_ReadOnly ); |
950 | m3uList->readPls(); | 883 | m3uList->readPls(); |
951 | 884 | ||
952 | for ( QStringList::ConstIterator it = m3uList->begin(); it != m3uList->end(); ++it ) { | 885 | for ( QStringList::ConstIterator it = m3uList->begin(); it != m3uList->end(); ++it ) { |
953 | s = *it; | 886 | s = *it; |
954 | s.replace( QRegExp( "%20" )," " ); | 887 | // s.replace( QRegExp( "%20" )," " ); |
955 | DocLnk lnk( s ); | 888 | DocLnk lnk( s ); |
956 | QFileInfo f( s ); | 889 | QFileInfo f( s ); |
957 | QString name = f.baseName(); | 890 | QString name = f.baseName(); |
958 | 891 | ||
959 | if( name.left( 4 ) == "http" ) { | 892 | if( name.left( 4 ) == "http" ) { |
960 | name = s.right( s.length() - 7); | 893 | name = s.right( s.length() - 7); |
961 | } else { | 894 | } else { |
962 | name = s; | 895 | name = s; |
963 | } | 896 | } |
964 | 897 | ||
965 | name = name.right( name.length() - name.findRev( "\\", -1, TRUE) - 1 ); | 898 | name = name.right( name.length() - name.findRev( "\\", -1, TRUE) - 1 ); |
966 | 899 | ||
967 | lnk.setName( name ); | 900 | lnk.setName( name ); |
968 | if( s.at( s.length() - 4) == '.') {// if this is probably a file | 901 | if( s.at( s.length() - 4) == '.') {// if this is probably a file |
969 | lnk.setFile( s ); | 902 | lnk.setFile( s ); |
970 | } else { //if its a url | 903 | } else { //if its a url |
971 | if( name.right( 1 ).find( '/' ) == -1) { | 904 | if( name.right( 1 ).find( '/' ) == -1) { |
972 | s += "/"; | 905 | s += "/"; |
973 | } | 906 | } |
974 | lnk.setFile( s ); | 907 | lnk.setFile( s ); |
975 | } | 908 | } |
976 | lnk.setType( "audio/x-mpegurl" ); | 909 | lnk.setType( "audio/x-mpegurl" ); |
977 | 910 | ||
978 | lnk.writeLink(); | 911 | lnk.writeLink(); |
979 | d->selectedFiles->addToSelection( lnk ); | 912 | d->selectedFiles->addToSelection( lnk ); |
980 | } | 913 | } |
981 | 914 | ||
982 | m3uList->close(); | 915 | m3uList->close(); |
983 | if(m3uList) delete m3uList; | 916 | if(m3uList) delete m3uList; |
984 | } | 917 | } |
985 | 918 | ||
986 | /* | 919 | /* |
920 | writes current playlist to current m3u file */ | ||
921 | void PlayListWidget::writeCurrentM3u() { | ||
922 | qDebug("writting to current m3u"); | ||
923 | Config cfg( "OpiePlayer" ); | ||
924 | cfg.setGroup("PlayList"); | ||
925 | QString currentPlaylist = cfg.readEntry("CurrentPlaylist",""); | ||
926 | // int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 ); | ||
927 | Om3u *m3uList; | ||
928 | m3uList = new Om3u( currentPlaylist, IO_ReadWrite ); | ||
929 | d->selectedFiles->first(); | ||
930 | |||
931 | do { | ||
932 | m3uList->add( d->selectedFiles->current()->file()); | ||
933 | } | ||
934 | while ( d->selectedFiles->next() ); | ||
935 | // qDebug( list ); | ||
936 | m3uList->write(); | ||
937 | if(m3uList) delete m3uList; | ||
938 | } | ||
939 | |||
940 | /* | ||
987 | writes current playlist to m3u file */ | 941 | writes current playlist to m3u file */ |
988 | void PlayListWidget::writem3u() { | 942 | void PlayListWidget::writem3u() { |
989 | InputDialog *fileDlg; | 943 | InputDialog *fileDlg; |
990 | fileDlg = new InputDialog( this, tr( "Save m3u Playlist " ), TRUE, 0); | 944 | fileDlg = new InputDialog( this, tr( "Save m3u Playlist " ), TRUE, 0); |
991 | fileDlg->exec(); | 945 | fileDlg->exec(); |
992 | QString name, filename, list; | 946 | QString name, filename, list; |
993 | Om3u *m3uList; | 947 | Om3u *m3uList; |
994 | 948 | ||
995 | if( fileDlg->result() == 1 ) { | 949 | if( fileDlg->result() == 1 ) { |
996 | name = fileDlg->text(); | 950 | name = fileDlg->text(); |
997 | qDebug( filename ); | 951 | qDebug( filename ); |
998 | 952 | ||
999 | if( name.left( 1) != "/" ) { | 953 | if( name.left( 1) != "/" ) { |
1000 | filename = QPEApplication::documentDir() + "/" + name; | 954 | filename = QPEApplication::documentDir() + "/" + name; |
1001 | } | 955 | } |
1002 | 956 | ||
1003 | if( name.right( 3 ) != "m3u" ) { | 957 | if( name.right( 3 ) != "m3u" ) { |
1004 | filename = QPEApplication::documentDir() + "/" +name+".m3u"; | 958 | filename = QPEApplication::documentDir() + "/" +name+".m3u"; |
1005 | } | 959 | } |
1006 | 960 | ||
1007 | m3uList = new Om3u(filename); | 961 | m3uList = new Om3u(filename, IO_ReadWrite); |
1008 | 962 | ||
1009 | d->selectedFiles->first(); | 963 | d->selectedFiles->first(); |
1010 | 964 | ||
1011 | do { | 965 | do { |
1012 | m3uList->add( d->selectedFiles->current()->file()); | 966 | m3uList->add( d->selectedFiles->current()->file()); |
1013 | } | 967 | } |
1014 | while ( d->selectedFiles->next() ); | 968 | while ( d->selectedFiles->next() ); |
1015 | // qDebug( list ); | 969 | // qDebug( list ); |
1016 | |||
1017 | m3uList->write(); | 970 | m3uList->write(); |
1018 | m3uList->close(); | ||
1019 | } | 971 | } |
1020 | if(m3uList) delete m3uList; | 972 | if(m3uList) delete m3uList; |
1021 | if(fileDlg) delete fileDlg; | 973 | if(fileDlg) delete fileDlg; |
1022 | 974 | ||
1023 | DocLnk lnk; | 975 | DocLnk lnk; |
1024 | lnk.setFile( filename); | 976 | lnk.setFile( filename); |
1025 | lnk.setIcon("opieplayer2/playlist2"); | 977 | lnk.setIcon("opieplayer2/playlist2"); |
1026 | lnk.setName( name); //sets file name | 978 | lnk.setName( name); //sets file name |
1027 | 979 | ||
1028 | // qDebug(filename); | 980 | // qDebug(filename); |
1029 | Config config( "OpiePlayer" ); | 981 | Config config( "OpiePlayer" ); |
1030 | config.setGroup( "PlayList" ); | 982 | config.setGroup( "PlayList" ); |
1031 | 983 | ||
1032 | config.writeEntry("CurrentPlaylist",filename); | 984 | config.writeEntry("CurrentPlaylist",filename); |
1033 | currentPlayList=filename; | 985 | currentPlayList=filename; |
1034 | 986 | ||
1035 | if(!lnk.writeLink()) { | 987 | if(!lnk.writeLink()) { |
1036 | qDebug("Writing doclink did not work"); | 988 | qDebug("Writing doclink did not work"); |
1037 | } | 989 | } |
1038 | 990 | ||
1039 | setCaption(tr("OpiePlayer: ") + name); | 991 | setCaption(tr("OpiePlayer: ") + name); |
1040 | } | 992 | } |
1041 | 993 | ||
1042 | void PlayListWidget::keyReleaseEvent( QKeyEvent *e ) { | 994 | void PlayListWidget::keyReleaseEvent( QKeyEvent *e ) { |
diff --git a/noncore/multimedia/opieplayer2/playlistwidget.h b/noncore/multimedia/opieplayer2/playlistwidget.h index 428821a..8a77619 100644 --- a/noncore/multimedia/opieplayer2/playlistwidget.h +++ b/noncore/multimedia/opieplayer2/playlistwidget.h | |||
@@ -72,48 +72,49 @@ public slots: | |||
72 | bool first(); | 72 | bool first(); |
73 | bool last(); | 73 | bool last(); |
74 | bool next(); | 74 | bool next(); |
75 | bool prev(); | 75 | bool prev(); |
76 | void writeConfig( Config& cfg ) const; | 76 | void writeConfig( Config& cfg ) const; |
77 | QString currentFileListPathName(); | 77 | QString currentFileListPathName(); |
78 | protected: | 78 | protected: |
79 | void keyReleaseEvent( QKeyEvent *e); | 79 | void keyReleaseEvent( QKeyEvent *e); |
80 | 80 | ||
81 | private: | 81 | private: |
82 | int defaultSkinIndex; | 82 | int defaultSkinIndex; |
83 | bool audioScan, videoScan; | 83 | bool audioScan, videoScan; |
84 | void readm3u(const QString &); | 84 | void readm3u(const QString &); |
85 | void readPls(const QString &); | 85 | void readPls(const QString &); |
86 | void initializeStates(); | 86 | void initializeStates(); |
87 | void readConfig( Config& cfg ); | 87 | void readConfig( Config& cfg ); |
88 | void populateAudioView(); | 88 | void populateAudioView(); |
89 | void populateVideoView(); | 89 | void populateVideoView(); |
90 | 90 | ||
91 | private slots: | 91 | private slots: |
92 | void populateSkinsMenu(); | 92 | void populateSkinsMenu(); |
93 | void skinsMenuActivated(int); | 93 | void skinsMenuActivated(int); |
94 | void pmViewActivated(int); | 94 | void pmViewActivated(int); |
95 | void writem3u(); | 95 | void writem3u(); |
96 | void writeCurrentM3u(); | ||
96 | void scanForAudio(); | 97 | void scanForAudio(); |
97 | void scanForVideo(); | 98 | void scanForVideo(); |
98 | void openFile(); | 99 | void openFile(); |
99 | void setDocument( const QString& fileref ); | 100 | void setDocument( const QString& fileref ); |
100 | void addToSelection( const DocLnk& ); // Add a media file to the playlist | 101 | void addToSelection( const DocLnk& ); // Add a media file to the playlist |
101 | void addToSelection( QListViewItem* ); // Add a media file to the playlist | 102 | void addToSelection( QListViewItem* ); // Add a media file to the playlist |
102 | void setPlaylist( bool ); // Show/Hide the playlist | 103 | void setPlaylist( bool ); // Show/Hide the playlist |
103 | void clearList(); | 104 | void clearList(); |
104 | void addAllToList(); | 105 | void addAllToList(); |
105 | void addAllMusicToList(); | 106 | void addAllMusicToList(); |
106 | void addAllVideoToList(); | 107 | void addAllVideoToList(); |
107 | void saveList(); // Save the playlist | 108 | void saveList(); // Save the playlist |
108 | void loadList( const DocLnk &); // Load a playlist | 109 | void loadList( const DocLnk &); // Load a playlist |
109 | void playIt( QListViewItem *); | 110 | void playIt( QListViewItem *); |
110 | void btnPlay(bool); | 111 | void btnPlay(bool); |
111 | void deletePlaylist(); | 112 | void deletePlaylist(); |
112 | void addSelected(); | 113 | void addSelected(); |
113 | void removeSelected(); | 114 | void removeSelected(); |
114 | void tabChanged(QWidget*); | 115 | void tabChanged(QWidget*); |
115 | void viewPressed( int, QListViewItem *, const QPoint&, int); | 116 | void viewPressed( int, QListViewItem *, const QPoint&, int); |
116 | void playlistViewPressed( int, QListViewItem *, const QPoint&, int); | 117 | void playlistViewPressed( int, QListViewItem *, const QPoint&, int); |
117 | void playSelected(); | 118 | void playSelected(); |
118 | }; | 119 | }; |
119 | 120 | ||