Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
M
mpd
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Иван Мажукин
mpd
Commits
8929f88e
Commit
8929f88e
authored
Sep 05, 2013
by
Max Kellermann
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
PlaylistPlugin: add interface SongEnumerator
Replaces struct playlist_provider.
parent
5348808b
Show whitespace changes
Inline
Side-by-side
Showing
26 changed files
with
204 additions
and
315 deletions
+204
-315
Makefile.am
Makefile.am
+2
-2
MemorySongEnumerator.cxx
src/MemorySongEnumerator.cxx
+4
-41
MemorySongEnumerator.hxx
src/MemorySongEnumerator.hxx
+5
-6
PlaylistAny.cxx
src/PlaylistAny.cxx
+3
-4
PlaylistAny.hxx
src/PlaylistAny.hxx
+2
-2
PlaylistMapper.cxx
src/PlaylistMapper.cxx
+9
-13
PlaylistMapper.hxx
src/PlaylistMapper.hxx
+2
-1
PlaylistPlugin.hxx
src/PlaylistPlugin.hxx
+5
-35
PlaylistPrint.cxx
src/PlaylistPrint.cxx
+6
-6
PlaylistQueue.cxx
src/PlaylistQueue.cxx
+7
-6
PlaylistQueue.hxx
src/PlaylistQueue.hxx
+2
-2
PlaylistRegistry.cxx
src/PlaylistRegistry.cxx
+17
-25
PlaylistRegistry.hxx
src/PlaylistRegistry.hxx
+4
-4
SongEnumerator.hxx
src/SongEnumerator.hxx
+41
-0
AsxPlaylistPlugin.cxx
src/playlist/AsxPlaylistPlugin.cxx
+5
-6
CuePlaylistPlugin.cxx
src/playlist/CuePlaylistPlugin.cxx
+14
-29
DespotifyPlaylistPlugin.cxx
src/playlist/DespotifyPlaylistPlugin.cxx
+4
-5
EmbeddedCuePlaylistPlugin.cxx
src/playlist/EmbeddedCuePlaylistPlugin.cxx
+10
-28
ExtM3uPlaylistPlugin.cxx
src/playlist/ExtM3uPlaylistPlugin.cxx
+17
-23
LastFMPlaylistPlugin.cxx
src/playlist/LastFMPlaylistPlugin.cxx
+13
-29
M3uPlaylistPlugin.cxx
src/playlist/M3uPlaylistPlugin.cxx
+10
-22
PlsPlaylistPlugin.cxx
src/playlist/PlsPlaylistPlugin.cxx
+4
-5
RssPlaylistPlugin.cxx
src/playlist/RssPlaylistPlugin.cxx
+5
-6
SoundCloudPlaylistPlugin.cxx
src/playlist/SoundCloudPlaylistPlugin.cxx
+4
-5
XspfPlaylistPlugin.cxx
src/playlist/XspfPlaylistPlugin.cxx
+5
-6
dump_playlist.cxx
test/dump_playlist.cxx
+4
-4
No files found.
Makefile.am
View file @
8929f88e
...
@@ -917,8 +917,8 @@ endif
...
@@ -917,8 +917,8 @@ endif
libplaylist_plugins_a_SOURCES
=
\
libplaylist_plugins_a_SOURCES
=
\
src/PlaylistPlugin.hxx
\
src/PlaylistPlugin.hxx
\
src/
playlist/MemoryPlaylistProvider.c
xx
\
src/
SongEnumerator.h
xx
\
src/
playlist/MemoryPlaylistProvide
r.hxx
\
src/
MemorySongEnumerator.cxx src/MemorySongEnumerato
r.hxx
\
src/playlist/ExtM3uPlaylistPlugin.cxx
\
src/playlist/ExtM3uPlaylistPlugin.cxx
\
src/playlist/ExtM3uPlaylistPlugin.hxx
\
src/playlist/ExtM3uPlaylistPlugin.hxx
\
src/playlist/M3uPlaylistPlugin.cxx
\
src/playlist/M3uPlaylistPlugin.cxx
\
...
...
src/
playlist/MemoryPlaylistProvide
r.cxx
→
src/
MemorySongEnumerato
r.cxx
View file @
8929f88e
...
@@ -18,50 +18,13 @@
...
@@ -18,50 +18,13 @@
*/
*/
#include "config.h"
#include "config.h"
#include "MemoryPlaylistProvider.hxx"
#include "MemorySongEnumerator.hxx"
#include "Song.hxx"
static
void
Song
*
memory_playlist_close
(
struct
playlist_provider
*
_playlist
)
MemorySongEnumerator
::
NextSong
()
{
MemoryPlaylistProvider
*
playlist
=
(
MemoryPlaylistProvider
*
)
_playlist
;
delete
playlist
;
}
static
Song
*
memory_playlist_read
(
struct
playlist_provider
*
_playlist
)
{
MemoryPlaylistProvider
*
playlist
=
(
MemoryPlaylistProvider
*
)
_playlist
;
return
playlist
->
Read
();
}
static
constexpr
struct
playlist_plugin
memory_playlist_plugin
=
{
nullptr
,
nullptr
,
nullptr
,
nullptr
,
nullptr
,
memory_playlist_close
,
memory_playlist_read
,
nullptr
,
nullptr
,
nullptr
,
};
MemoryPlaylistProvider
::
MemoryPlaylistProvider
(
std
::
forward_list
<
SongPointer
>
&&
_songs
)
:
songs
(
std
::
move
(
_songs
))
{
playlist_provider_init
(
this
,
&
memory_playlist_plugin
);
}
inline
Song
*
MemoryPlaylistProvider
::
Read
()
{
{
if
(
songs
.
empty
())
if
(
songs
.
empty
())
return
NULL
;
return
nullptr
;
auto
result
=
songs
.
front
().
Steal
();
auto
result
=
songs
.
front
().
Steal
();
songs
.
pop_front
();
songs
.
pop_front
();
...
...
src/
playlist/MemoryPlaylistProvide
r.hxx
→
src/
MemorySongEnumerato
r.hxx
View file @
8929f88e
...
@@ -20,20 +20,19 @@
...
@@ -20,20 +20,19 @@
#ifndef MPD_MEMORY_PLAYLIST_PROVIDER_HXX
#ifndef MPD_MEMORY_PLAYLIST_PROVIDER_HXX
#define MPD_MEMORY_PLAYLIST_PROVIDER_HXX
#define MPD_MEMORY_PLAYLIST_PROVIDER_HXX
#include "
PlaylistPlugin
.hxx"
#include "
SongEnumerator
.hxx"
#include "SongPointer.hxx"
#include "SongPointer.hxx"
#include <forward_list>
#include <forward_list>
struct
Song
;
class
MemorySongEnumerator
final
:
public
SongEnumerator
{
class
MemoryPlaylistProvider
:
public
playlist_provider
{
std
::
forward_list
<
SongPointer
>
songs
;
std
::
forward_list
<
SongPointer
>
songs
;
public
:
public
:
MemoryPlaylistProvider
(
std
::
forward_list
<
SongPointer
>
&&
_songs
);
MemorySongEnumerator
(
std
::
forward_list
<
SongPointer
>
&&
_songs
)
:
songs
(
std
::
move
(
_songs
))
{}
Song
*
Read
()
;
virtual
Song
*
NextSong
()
override
;
};
};
#endif
#endif
src/PlaylistAny.cxx
View file @
8929f88e
...
@@ -27,14 +27,13 @@
...
@@ -27,14 +27,13 @@
#include <assert.h>
#include <assert.h>
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
playlist_open_remote
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
,
playlist_open_remote
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
,
struct
input_stream
**
is_r
)
struct
input_stream
**
is_r
)
{
{
assert
(
uri_has_scheme
(
uri
));
assert
(
uri_has_scheme
(
uri
));
struct
playlist_provider
*
playlist
=
SongEnumerator
*
playlist
=
playlist_list_open_uri
(
uri
,
mutex
,
cond
);
playlist_list_open_uri
(
uri
,
mutex
,
cond
);
if
(
playlist
!=
NULL
)
{
if
(
playlist
!=
NULL
)
{
*
is_r
=
NULL
;
*
is_r
=
NULL
;
return
playlist
;
return
playlist
;
...
@@ -60,7 +59,7 @@ playlist_open_remote(const char *uri, Mutex &mutex, Cond &cond,
...
@@ -60,7 +59,7 @@ playlist_open_remote(const char *uri, Mutex &mutex, Cond &cond,
return
playlist
;
return
playlist
;
}
}
struct
playlist_provide
r
*
SongEnumerato
r
*
playlist_open_any
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
,
playlist_open_any
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
,
struct
input_stream
**
is_r
)
struct
input_stream
**
is_r
)
{
{
...
...
src/PlaylistAny.hxx
View file @
8929f88e
...
@@ -23,7 +23,7 @@
...
@@ -23,7 +23,7 @@
#include "thread/Mutex.hxx"
#include "thread/Mutex.hxx"
#include "thread/Cond.hxx"
#include "thread/Cond.hxx"
struct
playlist_provide
r
;
class
SongEnumerato
r
;
struct
input_stream
;
struct
input_stream
;
/**
/**
...
@@ -35,7 +35,7 @@ struct input_stream;
...
@@ -35,7 +35,7 @@ struct input_stream;
* here, which must be closed after the playlist_provider object is
* here, which must be closed after the playlist_provider object is
* freed
* freed
*/
*/
struct
playlist_provide
r
*
SongEnumerato
r
*
playlist_open_any
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
,
playlist_open_any
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
,
struct
input_stream
**
is_r
);
struct
input_stream
**
is_r
);
...
...
src/PlaylistMapper.cxx
View file @
8929f88e
...
@@ -27,13 +27,11 @@
...
@@ -27,13 +27,11 @@
#include <assert.h>
#include <assert.h>
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
playlist_open_path
(
const
char
*
path_fs
,
Mutex
&
mutex
,
Cond
&
cond
,
playlist_open_path
(
const
char
*
path_fs
,
Mutex
&
mutex
,
Cond
&
cond
,
struct
input_stream
**
is_r
)
struct
input_stream
**
is_r
)
{
{
struct
playlist_provider
*
playlist
;
auto
playlist
=
playlist_list_open_uri
(
path_fs
,
mutex
,
cond
);
playlist
=
playlist_list_open_uri
(
path_fs
,
mutex
,
cond
);
if
(
playlist
!=
NULL
)
if
(
playlist
!=
NULL
)
*
is_r
=
NULL
;
*
is_r
=
NULL
;
else
else
...
@@ -45,7 +43,7 @@ playlist_open_path(const char *path_fs, Mutex &mutex, Cond &cond,
...
@@ -45,7 +43,7 @@ playlist_open_path(const char *path_fs, Mutex &mutex, Cond &cond,
/**
/**
* Load a playlist from the configured playlist directory.
* Load a playlist from the configured playlist directory.
*/
*/
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
playlist_open_in_playlist_dir
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
,
playlist_open_in_playlist_dir
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
,
struct
input_stream
**
is_r
)
struct
input_stream
**
is_r
)
{
{
...
@@ -59,8 +57,7 @@ playlist_open_in_playlist_dir(const char *uri, Mutex &mutex, Cond &cond,
...
@@ -59,8 +57,7 @@ playlist_open_in_playlist_dir(const char *uri, Mutex &mutex, Cond &cond,
path_fs
=
g_build_filename
(
playlist_directory_fs
.
c_str
(),
uri
,
NULL
);
path_fs
=
g_build_filename
(
playlist_directory_fs
.
c_str
(),
uri
,
NULL
);
struct
playlist_provider
*
playlist
=
auto
playlist
=
playlist_open_path
(
path_fs
,
mutex
,
cond
,
is_r
);
playlist_open_path
(
path_fs
,
mutex
,
cond
,
is_r
);
g_free
(
path_fs
);
g_free
(
path_fs
);
return
playlist
;
return
playlist
;
...
@@ -69,7 +66,7 @@ playlist_open_in_playlist_dir(const char *uri, Mutex &mutex, Cond &cond,
...
@@ -69,7 +66,7 @@ playlist_open_in_playlist_dir(const char *uri, Mutex &mutex, Cond &cond,
/**
/**
* Load a playlist from the configured music directory.
* Load a playlist from the configured music directory.
*/
*/
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
playlist_open_in_music_dir
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
,
playlist_open_in_music_dir
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
,
struct
input_stream
**
is_r
)
struct
input_stream
**
is_r
)
{
{
...
@@ -82,21 +79,20 @@ playlist_open_in_music_dir(const char *uri, Mutex &mutex, Cond &cond,
...
@@ -82,21 +79,20 @@ playlist_open_in_music_dir(const char *uri, Mutex &mutex, Cond &cond,
return
playlist_open_path
(
path
.
c_str
(),
mutex
,
cond
,
is_r
);
return
playlist_open_path
(
path
.
c_str
(),
mutex
,
cond
,
is_r
);
}
}
struct
playlist_provide
r
*
SongEnumerato
r
*
playlist_mapper_open
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
,
playlist_mapper_open
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
,
struct
input_stream
**
is_r
)
struct
input_stream
**
is_r
)
{
{
struct
playlist_provider
*
playlist
;
if
(
spl_valid_name
(
uri
))
{
if
(
spl_valid_name
(
uri
))
{
playlist
=
playlist_open_in_playlist_dir
(
uri
,
mutex
,
cond
,
auto
playlist
=
playlist_open_in_playlist_dir
(
uri
,
mutex
,
cond
,
is_r
);
is_r
);
if
(
playlist
!=
NULL
)
if
(
playlist
!=
NULL
)
return
playlist
;
return
playlist
;
}
}
if
(
uri_safe_local
(
uri
))
{
if
(
uri_safe_local
(
uri
))
{
playlist
=
playlist_open_in_music_dir
(
uri
,
mutex
,
cond
,
is_r
);
auto
playlist
=
playlist_open_in_music_dir
(
uri
,
mutex
,
cond
,
is_r
);
if
(
playlist
!=
NULL
)
if
(
playlist
!=
NULL
)
return
playlist
;
return
playlist
;
}
}
...
...
src/PlaylistMapper.hxx
View file @
8929f88e
...
@@ -23,6 +23,7 @@
...
@@ -23,6 +23,7 @@
#include "thread/Mutex.hxx"
#include "thread/Mutex.hxx"
#include "thread/Cond.hxx"
#include "thread/Cond.hxx"
class
SongEnumerator
;
struct
input_stream
;
struct
input_stream
;
/**
/**
...
@@ -33,7 +34,7 @@ struct input_stream;
...
@@ -33,7 +34,7 @@ struct input_stream;
* here, which must be closed after the playlist_provider object is
* here, which must be closed after the playlist_provider object is
* freed
* freed
*/
*/
struct
playlist_provide
r
*
SongEnumerato
r
*
playlist_mapper_open
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
,
playlist_mapper_open
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
,
struct
input_stream
**
is_r
);
struct
input_stream
**
is_r
);
...
...
src/PlaylistPlugin.hxx
View file @
8929f88e
...
@@ -26,21 +26,7 @@
...
@@ -26,21 +26,7 @@
struct
config_param
;
struct
config_param
;
struct
input_stream
;
struct
input_stream
;
struct
Tag
;
struct
Tag
;
struct
Song
;
class
SongEnumerator
;
/**
* An object which provides the contents of a playlist.
*/
struct
playlist_provider
{
const
struct
playlist_plugin
*
plugin
;
};
static
inline
void
playlist_provider_init
(
struct
playlist_provider
*
playlist
,
const
struct
playlist_plugin
*
plugin
)
{
playlist
->
plugin
=
plugin
;
}
struct
playlist_plugin
{
struct
playlist_plugin
{
const
char
*
name
;
const
char
*
name
;
...
@@ -65,7 +51,7 @@ struct playlist_plugin {
...
@@ -65,7 +51,7 @@ struct playlist_plugin {
* Opens the playlist on the specified URI. This URI has
* Opens the playlist on the specified URI. This URI has
* either matched one of the schemes or one of the suffixes.
* either matched one of the schemes or one of the suffixes.
*/
*/
struct
playlist_provide
r
*
(
*
open_uri
)(
const
char
*
uri
,
SongEnumerato
r
*
(
*
open_uri
)(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
);
Mutex
&
mutex
,
Cond
&
cond
);
/**
/**
...
@@ -73,11 +59,7 @@ struct playlist_plugin {
...
@@ -73,11 +59,7 @@ struct playlist_plugin {
* either matched one of the suffixes or one of the MIME
* either matched one of the suffixes or one of the MIME
* types.
* types.
*/
*/
struct
playlist_provider
*
(
*
open_stream
)(
struct
input_stream
*
is
);
SongEnumerator
*
(
*
open_stream
)(
struct
input_stream
*
is
);
void
(
*
close
)(
struct
playlist_provider
*
playlist
);
Song
*
(
*
read
)(
struct
playlist_provider
*
playlist
);
const
char
*
const
*
schemes
;
const
char
*
const
*
schemes
;
const
char
*
const
*
suffixes
;
const
char
*
const
*
suffixes
;
...
@@ -111,30 +93,18 @@ playlist_plugin_finish(const struct playlist_plugin *plugin)
...
@@ -111,30 +93,18 @@ playlist_plugin_finish(const struct playlist_plugin *plugin)
plugin
->
finish
();
plugin
->
finish
();
}
}
static
inline
struct
playlist_provide
r
*
static
inline
SongEnumerato
r
*
playlist_plugin_open_uri
(
const
struct
playlist_plugin
*
plugin
,
const
char
*
uri
,
playlist_plugin_open_uri
(
const
struct
playlist_plugin
*
plugin
,
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
)
Mutex
&
mutex
,
Cond
&
cond
)
{
{
return
plugin
->
open_uri
(
uri
,
mutex
,
cond
);
return
plugin
->
open_uri
(
uri
,
mutex
,
cond
);
}
}
static
inline
struct
playlist_provide
r
*
static
inline
SongEnumerato
r
*
playlist_plugin_open_stream
(
const
struct
playlist_plugin
*
plugin
,
playlist_plugin_open_stream
(
const
struct
playlist_plugin
*
plugin
,
struct
input_stream
*
is
)
struct
input_stream
*
is
)
{
{
return
plugin
->
open_stream
(
is
);
return
plugin
->
open_stream
(
is
);
}
}
static
inline
void
playlist_plugin_close
(
struct
playlist_provider
*
playlist
)
{
playlist
->
plugin
->
close
(
playlist
);
}
static
inline
Song
*
playlist_plugin_read
(
struct
playlist_provider
*
playlist
)
{
return
playlist
->
plugin
->
read
(
playlist
);
}
#endif
#endif
src/PlaylistPrint.cxx
View file @
8929f88e
...
@@ -26,6 +26,7 @@
...
@@ -26,6 +26,7 @@
#include "PlaylistRegistry.hxx"
#include "PlaylistRegistry.hxx"
#include "PlaylistPlugin.hxx"
#include "PlaylistPlugin.hxx"
#include "QueuePrint.hxx"
#include "QueuePrint.hxx"
#include "SongEnumerator.hxx"
#include "SongPrint.hxx"
#include "SongPrint.hxx"
#include "DatabaseGlue.hxx"
#include "DatabaseGlue.hxx"
#include "DatabasePlugin.hxx"
#include "DatabasePlugin.hxx"
...
@@ -145,12 +146,12 @@ spl_print(Client *client, const char *name_utf8, bool detail,
...
@@ -145,12 +146,12 @@ spl_print(Client *client, const char *name_utf8, bool detail,
static
void
static
void
playlist_provider_print
(
Client
*
client
,
const
char
*
uri
,
playlist_provider_print
(
Client
*
client
,
const
char
*
uri
,
struct
playlist_provider
*
playlist
,
bool
detail
)
SongEnumerator
&
e
,
bool
detail
)
{
{
Song
*
song
;
Song
*
song
;
char
*
base_uri
=
uri
!=
NULL
?
g_path_get_dirname
(
uri
)
:
NULL
;
char
*
base_uri
=
uri
!=
NULL
?
g_path_get_dirname
(
uri
)
:
NULL
;
while
((
song
=
playlist_plugin_read
(
playlist
))
!=
NULL
)
{
while
((
song
=
e
.
NextSong
())
!=
nullptr
)
{
song
=
playlist_check_translate_song
(
song
,
base_uri
,
false
);
song
=
playlist_check_translate_song
(
song
,
base_uri
,
false
);
if
(
song
==
NULL
)
if
(
song
==
NULL
)
continue
;
continue
;
...
@@ -173,13 +174,12 @@ playlist_file_print(Client *client, const char *uri, bool detail)
...
@@ -173,13 +174,12 @@ playlist_file_print(Client *client, const char *uri, bool detail)
Cond
cond
;
Cond
cond
;
struct
input_stream
*
is
;
struct
input_stream
*
is
;
struct
playlist_provider
*
playlist
=
SongEnumerator
*
playlist
=
playlist_open_any
(
uri
,
mutex
,
cond
,
&
is
);
playlist_open_any
(
uri
,
mutex
,
cond
,
&
is
);
if
(
playlist
==
NULL
)
if
(
playlist
==
NULL
)
return
false
;
return
false
;
playlist_provider_print
(
client
,
uri
,
playlist
,
detail
);
playlist_provider_print
(
client
,
uri
,
*
playlist
,
detail
);
playlist_plugin_close
(
playlist
)
;
delete
playlist
;
if
(
is
!=
NULL
)
if
(
is
!=
NULL
)
is
->
Close
();
is
->
Close
();
...
...
src/PlaylistQueue.cxx
View file @
8929f88e
...
@@ -24,10 +24,11 @@
...
@@ -24,10 +24,11 @@
#include "PlaylistSong.hxx"
#include "PlaylistSong.hxx"
#include "Playlist.hxx"
#include "Playlist.hxx"
#include "InputStream.hxx"
#include "InputStream.hxx"
#include "SongEnumerator.hxx"
#include "Song.hxx"
#include "Song.hxx"
enum
playlist_result
enum
playlist_result
playlist_load_into_queue
(
const
char
*
uri
,
struct
playlist_provider
*
sourc
e
,
playlist_load_into_queue
(
const
char
*
uri
,
SongEnumerator
&
e
,
unsigned
start_index
,
unsigned
end_index
,
unsigned
start_index
,
unsigned
end_index
,
struct
playlist
*
dest
,
struct
player_control
*
pc
,
struct
playlist
*
dest
,
struct
player_control
*
pc
,
bool
secure
)
bool
secure
)
...
@@ -37,7 +38,7 @@ playlist_load_into_queue(const char *uri, struct playlist_provider *source,
...
@@ -37,7 +38,7 @@ playlist_load_into_queue(const char *uri, struct playlist_provider *source,
char
*
base_uri
=
uri
!=
NULL
?
g_path_get_dirname
(
uri
)
:
NULL
;
char
*
base_uri
=
uri
!=
NULL
?
g_path_get_dirname
(
uri
)
:
NULL
;
for
(
unsigned
i
=
0
;
for
(
unsigned
i
=
0
;
i
<
end_index
&&
(
song
=
playlist_plugin_read
(
source
))
!=
NULL
;
i
<
end_index
&&
(
song
=
e
.
NextSong
(
))
!=
NULL
;
++
i
)
{
++
i
)
{
if
(
i
<
start_index
)
{
if
(
i
<
start_index
)
{
/* skip songs before the start index */
/* skip songs before the start index */
...
@@ -72,15 +73,15 @@ playlist_open_into_queue(const char *uri,
...
@@ -72,15 +73,15 @@ playlist_open_into_queue(const char *uri,
Cond
cond
;
Cond
cond
;
struct
input_stream
*
is
;
struct
input_stream
*
is
;
struct
playlist_provider
*
playlist
=
auto
playlist
=
playlist_open_any
(
uri
,
mutex
,
cond
,
&
is
);
playlist_open_any
(
uri
,
mutex
,
cond
,
&
is
);
if
(
playlist
==
NULL
)
if
(
playlist
==
NULL
)
return
PLAYLIST_RESULT_NO_SUCH_LIST
;
return
PLAYLIST_RESULT_NO_SUCH_LIST
;
enum
playlist_result
result
=
enum
playlist_result
result
=
playlist_load_into_queue
(
uri
,
playlist
,
start_index
,
end_index
,
playlist_load_into_queue
(
uri
,
*
playlist
,
start_index
,
end_index
,
dest
,
pc
,
secure
);
dest
,
pc
,
secure
);
playlist_plugin_close
(
playlist
)
;
delete
playlist
;
if
(
is
!=
NULL
)
if
(
is
!=
NULL
)
is
->
Close
();
is
->
Close
();
...
...
src/PlaylistQueue.hxx
View file @
8929f88e
...
@@ -26,7 +26,7 @@
...
@@ -26,7 +26,7 @@
#include "PlaylistError.hxx"
#include "PlaylistError.hxx"
struct
playlist_provide
r
;
class
SongEnumerato
r
;
struct
playlist
;
struct
playlist
;
struct
player_control
;
struct
player_control
;
...
@@ -40,7 +40,7 @@ struct player_control;
...
@@ -40,7 +40,7 @@ struct player_control;
* @param end_index the index of the last song (excluding)
* @param end_index the index of the last song (excluding)
*/
*/
enum
playlist_result
enum
playlist_result
playlist_load_into_queue
(
const
char
*
uri
,
struct
playlist_provider
*
sourc
e
,
playlist_load_into_queue
(
const
char
*
uri
,
SongEnumerator
&
e
,
unsigned
start_index
,
unsigned
end_index
,
unsigned
start_index
,
unsigned
end_index
,
struct
playlist
*
dest
,
struct
player_control
*
pc
,
struct
playlist
*
dest
,
struct
player_control
*
pc
,
bool
secure
);
bool
secure
);
...
...
src/PlaylistRegistry.cxx
View file @
8929f88e
...
@@ -124,12 +124,12 @@ playlist_list_global_finish(void)
...
@@ -124,12 +124,12 @@ playlist_list_global_finish(void)
playlist_plugin_finish
(
plugin
);
playlist_plugin_finish
(
plugin
);
}
}
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
playlist_list_open_uri_scheme
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
,
playlist_list_open_uri_scheme
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
,
bool
*
tried
)
bool
*
tried
)
{
{
char
*
scheme
;
char
*
scheme
;
struct
playlist_provider
*
playlist
=
NULL
;
SongEnumerator
*
playlist
=
nullptr
;
assert
(
uri
!=
NULL
);
assert
(
uri
!=
NULL
);
...
@@ -158,12 +158,12 @@ playlist_list_open_uri_scheme(const char *uri, Mutex &mutex, Cond &cond,
...
@@ -158,12 +158,12 @@ playlist_list_open_uri_scheme(const char *uri, Mutex &mutex, Cond &cond,
return
playlist
;
return
playlist
;
}
}
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
playlist_list_open_uri_suffix
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
,
playlist_list_open_uri_suffix
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
,
const
bool
*
tried
)
const
bool
*
tried
)
{
{
const
char
*
suffix
;
const
char
*
suffix
;
struct
playlist_provider
*
playlist
=
NULL
;
SongEnumerator
*
playlist
=
nullptr
;
assert
(
uri
!=
NULL
);
assert
(
uri
!=
NULL
);
...
@@ -187,10 +187,9 @@ playlist_list_open_uri_suffix(const char *uri, Mutex &mutex, Cond &cond,
...
@@ -187,10 +187,9 @@ playlist_list_open_uri_suffix(const char *uri, Mutex &mutex, Cond &cond,
return
playlist
;
return
playlist
;
}
}
struct
playlist_provide
r
*
SongEnumerato
r
*
playlist_list_open_uri
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
)
playlist_list_open_uri
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
)
{
{
struct
playlist_provider
*
playlist
;
/** this array tracks which plugins have already been tried by
/** this array tracks which plugins have already been tried by
playlist_list_open_uri_scheme() */
playlist_list_open_uri_scheme() */
bool
tried
[
G_N_ELEMENTS
(
playlist_plugins
)
-
1
];
bool
tried
[
G_N_ELEMENTS
(
playlist_plugins
)
-
1
];
...
@@ -199,7 +198,7 @@ playlist_list_open_uri(const char *uri, Mutex &mutex, Cond &cond)
...
@@ -199,7 +198,7 @@ playlist_list_open_uri(const char *uri, Mutex &mutex, Cond &cond)
memset
(
tried
,
false
,
sizeof
(
tried
));
memset
(
tried
,
false
,
sizeof
(
tried
));
playlist
=
playlist_list_open_uri_scheme
(
uri
,
mutex
,
cond
,
tried
);
auto
playlist
=
playlist_list_open_uri_scheme
(
uri
,
mutex
,
cond
,
tried
);
if
(
playlist
==
NULL
)
if
(
playlist
==
NULL
)
playlist
=
playlist_list_open_uri_suffix
(
uri
,
mutex
,
cond
,
playlist
=
playlist_list_open_uri_suffix
(
uri
,
mutex
,
cond
,
tried
);
tried
);
...
@@ -207,11 +206,9 @@ playlist_list_open_uri(const char *uri, Mutex &mutex, Cond &cond)
...
@@ -207,11 +206,9 @@ playlist_list_open_uri(const char *uri, Mutex &mutex, Cond &cond)
return
playlist
;
return
playlist
;
}
}
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
playlist_list_open_stream_mime2
(
struct
input_stream
*
is
,
const
char
*
mime
)
playlist_list_open_stream_mime2
(
struct
input_stream
*
is
,
const
char
*
mime
)
{
{
struct
playlist_provider
*
playlist
;
assert
(
is
!=
NULL
);
assert
(
is
!=
NULL
);
assert
(
mime
!=
NULL
);
assert
(
mime
!=
NULL
);
...
@@ -223,7 +220,7 @@ playlist_list_open_stream_mime2(struct input_stream *is, const char *mime)
...
@@ -223,7 +220,7 @@ playlist_list_open_stream_mime2(struct input_stream *is, const char *mime)
fresh start */
fresh start */
is
->
Seek
(
0
,
SEEK_SET
,
IgnoreError
());
is
->
Seek
(
0
,
SEEK_SET
,
IgnoreError
());
playlist
=
playlist_plugin_open_stream
(
plugin
,
is
);
auto
playlist
=
playlist_plugin_open_stream
(
plugin
,
is
);
if
(
playlist
!=
NULL
)
if
(
playlist
!=
NULL
)
return
playlist
;
return
playlist
;
}
}
...
@@ -232,7 +229,7 @@ playlist_list_open_stream_mime2(struct input_stream *is, const char *mime)
...
@@ -232,7 +229,7 @@ playlist_list_open_stream_mime2(struct input_stream *is, const char *mime)
return
NULL
;
return
NULL
;
}
}
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
playlist_list_open_stream_mime
(
struct
input_stream
*
is
,
const
char
*
full_mime
)
playlist_list_open_stream_mime
(
struct
input_stream
*
is
,
const
char
*
full_mime
)
{
{
assert
(
full_mime
!=
NULL
);
assert
(
full_mime
!=
NULL
);
...
@@ -246,17 +243,14 @@ playlist_list_open_stream_mime(struct input_stream *is, const char *full_mime)
...
@@ -246,17 +243,14 @@ playlist_list_open_stream_mime(struct input_stream *is, const char *full_mime)
/* probe only the portion before the semicolon*/
/* probe only the portion before the semicolon*/
char
*
mime
=
g_strndup
(
full_mime
,
semicolon
-
full_mime
);
char
*
mime
=
g_strndup
(
full_mime
,
semicolon
-
full_mime
);
struct
playlist_provider
*
playlist
=
auto
playlist
=
playlist_list_open_stream_mime2
(
is
,
mime
);
playlist_list_open_stream_mime2
(
is
,
mime
);
g_free
(
mime
);
g_free
(
mime
);
return
playlist
;
return
playlist
;
}
}
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
playlist_list_open_stream_suffix
(
struct
input_stream
*
is
,
const
char
*
suffix
)
playlist_list_open_stream_suffix
(
struct
input_stream
*
is
,
const
char
*
suffix
)
{
{
struct
playlist_provider
*
playlist
;
assert
(
is
!=
NULL
);
assert
(
is
!=
NULL
);
assert
(
suffix
!=
NULL
);
assert
(
suffix
!=
NULL
);
...
@@ -268,7 +262,7 @@ playlist_list_open_stream_suffix(struct input_stream *is, const char *suffix)
...
@@ -268,7 +262,7 @@ playlist_list_open_stream_suffix(struct input_stream *is, const char *suffix)
fresh start */
fresh start */
is
->
Seek
(
0
,
SEEK_SET
,
IgnoreError
());
is
->
Seek
(
0
,
SEEK_SET
,
IgnoreError
());
playlist
=
playlist_plugin_open_stream
(
plugin
,
is
);
auto
playlist
=
playlist_plugin_open_stream
(
plugin
,
is
);
if
(
playlist
!=
NULL
)
if
(
playlist
!=
NULL
)
return
playlist
;
return
playlist
;
}
}
...
@@ -277,24 +271,23 @@ playlist_list_open_stream_suffix(struct input_stream *is, const char *suffix)
...
@@ -277,24 +271,23 @@ playlist_list_open_stream_suffix(struct input_stream *is, const char *suffix)
return
NULL
;
return
NULL
;
}
}
struct
playlist_provide
r
*
SongEnumerato
r
*
playlist_list_open_stream
(
struct
input_stream
*
is
,
const
char
*
uri
)
playlist_list_open_stream
(
struct
input_stream
*
is
,
const
char
*
uri
)
{
{
const
char
*
suffix
;
const
char
*
suffix
;
struct
playlist_provider
*
playlist
;
is
->
LockWaitReady
();
is
->
LockWaitReady
();
const
char
*
const
mime
=
is
->
GetMimeType
();
const
char
*
const
mime
=
is
->
GetMimeType
();
if
(
mime
!=
NULL
)
{
if
(
mime
!=
NULL
)
{
playlist
=
playlist_list_open_stream_mime
(
is
,
mime
);
auto
playlist
=
playlist_list_open_stream_mime
(
is
,
mime
);
if
(
playlist
!=
NULL
)
if
(
playlist
!=
NULL
)
return
playlist
;
return
playlist
;
}
}
suffix
=
uri
!=
NULL
?
uri_get_suffix
(
uri
)
:
NULL
;
suffix
=
uri
!=
NULL
?
uri_get_suffix
(
uri
)
:
NULL
;
if
(
suffix
!=
NULL
)
{
if
(
suffix
!=
NULL
)
{
playlist
=
playlist_list_open_stream_suffix
(
is
,
suffix
);
auto
playlist
=
playlist_list_open_stream_suffix
(
is
,
suffix
);
if
(
playlist
!=
NULL
)
if
(
playlist
!=
NULL
)
return
playlist
;
return
playlist
;
}
}
...
@@ -316,12 +309,11 @@ playlist_suffix_supported(const char *suffix)
...
@@ -316,12 +309,11 @@ playlist_suffix_supported(const char *suffix)
return
false
;
return
false
;
}
}
struct
playlist_provide
r
*
SongEnumerato
r
*
playlist_list_open_path
(
const
char
*
path_fs
,
Mutex
&
mutex
,
Cond
&
cond
,
playlist_list_open_path
(
const
char
*
path_fs
,
Mutex
&
mutex
,
Cond
&
cond
,
struct
input_stream
**
is_r
)
struct
input_stream
**
is_r
)
{
{
const
char
*
suffix
;
const
char
*
suffix
;
struct
playlist_provider
*
playlist
;
assert
(
path_fs
!=
NULL
);
assert
(
path_fs
!=
NULL
);
...
@@ -340,7 +332,7 @@ playlist_list_open_path(const char *path_fs, Mutex &mutex, Cond &cond,
...
@@ -340,7 +332,7 @@ playlist_list_open_path(const char *path_fs, Mutex &mutex, Cond &cond,
is
->
LockWaitReady
();
is
->
LockWaitReady
();
playlist
=
playlist_list_open_stream_suffix
(
is
,
suffix
);
auto
playlist
=
playlist_list_open_stream_suffix
(
is
,
suffix
);
if
(
playlist
!=
NULL
)
if
(
playlist
!=
NULL
)
*
is_r
=
is
;
*
is_r
=
is
;
else
else
...
...
src/PlaylistRegistry.hxx
View file @
8929f88e
...
@@ -23,7 +23,7 @@
...
@@ -23,7 +23,7 @@
#include "thread/Mutex.hxx"
#include "thread/Mutex.hxx"
#include "thread/Cond.hxx"
#include "thread/Cond.hxx"
struct
playlist_provide
r
;
class
SongEnumerato
r
;
struct
input_stream
;
struct
input_stream
;
extern
const
struct
playlist_plugin
*
const
playlist_plugins
[];
extern
const
struct
playlist_plugin
*
const
playlist_plugins
[];
...
@@ -49,7 +49,7 @@ playlist_list_global_finish(void);
...
@@ -49,7 +49,7 @@ playlist_list_global_finish(void);
/**
/**
* Opens a playlist by its URI.
* Opens a playlist by its URI.
*/
*/
struct
playlist_provide
r
*
SongEnumerato
r
*
playlist_list_open_uri
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
);
playlist_list_open_uri
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
);
/**
/**
...
@@ -59,7 +59,7 @@ playlist_list_open_uri(const char *uri, Mutex &mutex, Cond &cond);
...
@@ -59,7 +59,7 @@ playlist_list_open_uri(const char *uri, Mutex &mutex, Cond &cond);
* @param uri optional URI which was used to open the stream; may be
* @param uri optional URI which was used to open the stream; may be
* used to select the appropriate playlist plugin
* used to select the appropriate playlist plugin
*/
*/
struct
playlist_provide
r
*
SongEnumerato
r
*
playlist_list_open_stream
(
struct
input_stream
*
is
,
const
char
*
uri
);
playlist_list_open_stream
(
struct
input_stream
*
is
,
const
char
*
uri
);
/**
/**
...
@@ -77,7 +77,7 @@ playlist_suffix_supported(const char *suffix);
...
@@ -77,7 +77,7 @@ playlist_suffix_supported(const char *suffix);
* which must be closed after the playlist_provider object is freed
* which must be closed after the playlist_provider object is freed
* @return a playlist, or NULL on error
* @return a playlist, or NULL on error
*/
*/
struct
playlist_provide
r
*
SongEnumerato
r
*
playlist_list_open_path
(
const
char
*
path_fs
,
Mutex
&
mutex
,
Cond
&
cond
,
playlist_list_open_path
(
const
char
*
path_fs
,
Mutex
&
mutex
,
Cond
&
cond
,
struct
input_stream
**
is_r
);
struct
input_stream
**
is_r
);
...
...
src/SongEnumerator.hxx
0 → 100644
View file @
8929f88e
/*
* Copyright (C) 2003-2013 The Music Player Daemon Project
* http://www.musicpd.org
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#ifndef MPD_SONG_ENUMERATOR_HXX
#define MPD_SONG_ENUMERATOR_HXX
struct
Song
;
/**
* An object which provides serial access to a number of #Song
* objects. It is used to enumerate the contents of a playlist file.
*/
class
SongEnumerator
{
public
:
virtual
~
SongEnumerator
()
{}
/**
* Obtain the next song. The caller is responsible for
* freeing the returned #Song object. Returns nullptr if
* there are no more songs.
*/
virtual
Song
*
NextSong
()
=
0
;
};
#endif
src/playlist/AsxPlaylistPlugin.cxx
View file @
8929f88e
...
@@ -19,7 +19,8 @@
...
@@ -19,7 +19,8 @@
#include "config.h"
#include "config.h"
#include "AsxPlaylistPlugin.hxx"
#include "AsxPlaylistPlugin.hxx"
#include "MemoryPlaylistProvider.hxx"
#include "PlaylistPlugin.hxx"
#include "MemorySongEnumerator.hxx"
#include "InputStream.hxx"
#include "InputStream.hxx"
#include "Song.hxx"
#include "Song.hxx"
#include "Tag.hxx"
#include "Tag.hxx"
...
@@ -201,7 +202,7 @@ asx_parser_destroy(gpointer data)
...
@@ -201,7 +202,7 @@ asx_parser_destroy(gpointer data)
*
*
*/
*/
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
asx_open_stream
(
struct
input_stream
*
is
)
asx_open_stream
(
struct
input_stream
*
is
)
{
{
AsxParser
parser
;
AsxParser
parser
;
...
@@ -249,8 +250,8 @@ asx_open_stream(struct input_stream *is)
...
@@ -249,8 +250,8 @@ asx_open_stream(struct input_stream *is)
}
}
parser
.
songs
.
reverse
();
parser
.
songs
.
reverse
();
Memory
PlaylistProvide
r
*
playlist
=
Memory
SongEnumerato
r
*
playlist
=
new
Memory
PlaylistProvide
r
(
std
::
move
(
parser
.
songs
));
new
Memory
SongEnumerato
r
(
std
::
move
(
parser
.
songs
));
g_markup_parse_context_free
(
context
);
g_markup_parse_context_free
(
context
);
...
@@ -274,8 +275,6 @@ const struct playlist_plugin asx_playlist_plugin = {
...
@@ -274,8 +275,6 @@ const struct playlist_plugin asx_playlist_plugin = {
nullptr
,
nullptr
,
nullptr
,
nullptr
,
asx_open_stream
,
asx_open_stream
,
nullptr
,
nullptr
,
nullptr
,
nullptr
,
asx_suffixes
,
asx_suffixes
,
...
...
src/playlist/CuePlaylistPlugin.cxx
View file @
8929f88e
...
@@ -20,67 +20,54 @@
...
@@ -20,67 +20,54 @@
#include "config.h"
#include "config.h"
#include "CuePlaylistPlugin.hxx"
#include "CuePlaylistPlugin.hxx"
#include "PlaylistPlugin.hxx"
#include "PlaylistPlugin.hxx"
#include "SongEnumerator.hxx"
#include "Tag.hxx"
#include "Tag.hxx"
#include "Song.hxx"
#include "Song.hxx"
#include "cue/CueParser.hxx"
#include "cue/CueParser.hxx"
#include "TextInputStream.hxx"
#include "TextInputStream.hxx"
#include <glib.h>
#include <assert.h>
#include <assert.h>
#include <string.h>
#include <string.h>
#undef G_LOG_DOMAIN
#undef G_LOG_DOMAIN
#define G_LOG_DOMAIN "cue"
#define G_LOG_DOMAIN "cue"
struct
CuePlaylist
{
class
CuePlaylist
final
:
public
SongEnumerator
{
struct
playlist_provider
base
;
struct
input_stream
*
is
;
struct
input_stream
*
is
;
TextInputStream
tis
;
TextInputStream
tis
;
CueParser
parser
;
CueParser
parser
;
public
:
CuePlaylist
(
struct
input_stream
*
_is
)
CuePlaylist
(
struct
input_stream
*
_is
)
:
is
(
_is
),
tis
(
is
)
{
:
is
(
_is
),
tis
(
is
)
{
playlist_provider_init
(
&
base
,
&
cue_playlist_plugin
);
}
}
~
CuePlaylist
()
{
virtual
Song
*
NextSong
()
override
;
}
};
};
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
cue_playlist_open_stream
(
struct
input_stream
*
is
)
cue_playlist_open_stream
(
struct
input_stream
*
is
)
{
{
CuePlaylist
*
playlist
=
new
CuePlaylist
(
is
);
return
new
CuePlaylist
(
is
);
return
&
playlist
->
base
;
}
static
void
cue_playlist_close
(
struct
playlist_provider
*
_playlist
)
{
CuePlaylist
*
playlist
=
(
CuePlaylist
*
)
_playlist
;
delete
playlist
;
}
}
static
Song
*
Song
*
cue_playlist_read
(
struct
playlist_provider
*
_playlist
)
CuePlaylist
::
NextSong
(
)
{
{
CuePlaylist
*
playlist
=
(
CuePlaylist
*
)
_playlist
;
Song
*
song
=
parser
.
Get
();
Song
*
song
=
playlist
->
parser
.
Get
();
if
(
song
!=
NULL
)
if
(
song
!=
NULL
)
return
song
;
return
song
;
std
::
string
line
;
std
::
string
line
;
while
(
playlist
->
tis
.
ReadLine
(
line
))
{
while
(
tis
.
ReadLine
(
line
))
{
p
laylist
->
p
arser
.
Feed
(
line
.
c_str
());
parser
.
Feed
(
line
.
c_str
());
song
=
p
laylist
->
p
arser
.
Get
();
song
=
parser
.
Get
();
if
(
song
!=
NULL
)
if
(
song
!=
NULL
)
return
song
;
return
song
;
}
}
p
laylist
->
p
arser
.
Finish
();
parser
.
Finish
();
return
p
laylist
->
p
arser
.
Get
();
return
parser
.
Get
();
}
}
static
const
char
*
const
cue_playlist_suffixes
[]
=
{
static
const
char
*
const
cue_playlist_suffixes
[]
=
{
...
@@ -100,8 +87,6 @@ const struct playlist_plugin cue_playlist_plugin = {
...
@@ -100,8 +87,6 @@ const struct playlist_plugin cue_playlist_plugin = {
nullptr
,
nullptr
,
nullptr
,
nullptr
,
cue_playlist_open_stream
,
cue_playlist_open_stream
,
cue_playlist_close
,
cue_playlist_read
,
nullptr
,
nullptr
,
cue_playlist_suffixes
,
cue_playlist_suffixes
,
...
...
src/playlist/DespotifyPlaylistPlugin.cxx
View file @
8929f88e
...
@@ -20,7 +20,8 @@
...
@@ -20,7 +20,8 @@
#include "config.h"
#include "config.h"
#include "DespotifyPlaylistPlugin.hxx"
#include "DespotifyPlaylistPlugin.hxx"
#include "DespotifyUtils.hxx"
#include "DespotifyUtils.hxx"
#include "MemoryPlaylistProvider.hxx"
#include "PlaylistPlugin.hxx"
#include "MemorySongEnumerator.hxx"
#include "Tag.hxx"
#include "Tag.hxx"
#include "Song.hxx"
#include "Song.hxx"
...
@@ -86,7 +87,7 @@ parse_playlist(struct despotify_session *session,
...
@@ -86,7 +87,7 @@ parse_playlist(struct despotify_session *session,
return
true
;
return
true
;
}
}
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
despotify_playlist_open_uri
(
const
char
*
url
,
despotify_playlist_open_uri
(
const
char
*
url
,
gcc_unused
Mutex
&
mutex
,
gcc_unused
Cond
&
cond
)
gcc_unused
Mutex
&
mutex
,
gcc_unused
Cond
&
cond
)
{
{
...
@@ -122,7 +123,7 @@ despotify_playlist_open_uri(const char *url,
...
@@ -122,7 +123,7 @@ despotify_playlist_open_uri(const char *url,
return
nullptr
;
return
nullptr
;
songs
.
reverse
();
songs
.
reverse
();
return
new
Memory
PlaylistProvide
r
(
std
::
move
(
songs
));
return
new
Memory
SongEnumerato
r
(
std
::
move
(
songs
));
}
}
static
const
char
*
const
despotify_schemes
[]
=
{
static
const
char
*
const
despotify_schemes
[]
=
{
...
@@ -137,8 +138,6 @@ const struct playlist_plugin despotify_playlist_plugin = {
...
@@ -137,8 +138,6 @@ const struct playlist_plugin despotify_playlist_plugin = {
nullptr
,
nullptr
,
despotify_playlist_open_uri
,
despotify_playlist_open_uri
,
nullptr
,
nullptr
,
nullptr
,
nullptr
,
despotify_schemes
,
despotify_schemes
,
nullptr
,
nullptr
,
...
...
src/playlist/EmbeddedCuePlaylistPlugin.cxx
View file @
8929f88e
...
@@ -26,6 +26,7 @@
...
@@ -26,6 +26,7 @@
#include "config.h"
#include "config.h"
#include "EmbeddedCuePlaylistPlugin.hxx"
#include "EmbeddedCuePlaylistPlugin.hxx"
#include "PlaylistPlugin.hxx"
#include "PlaylistPlugin.hxx"
#include "SongEnumerator.hxx"
#include "Tag.hxx"
#include "Tag.hxx"
#include "TagHandler.hxx"
#include "TagHandler.hxx"
#include "tag/TagId3.hxx"
#include "tag/TagId3.hxx"
...
@@ -41,9 +42,8 @@
...
@@ -41,9 +42,8 @@
#undef G_LOG_DOMAIN
#undef G_LOG_DOMAIN
#define G_LOG_DOMAIN "cue"
#define G_LOG_DOMAIN "cue"
struct
EmbeddedCuePlaylist
{
class
EmbeddedCuePlaylist
final
:
public
SongEnumerator
{
struct
playlist_provider
base
;
public
:
/**
/**
* This is an override for the CUE's "FILE". An embedded CUE
* This is an override for the CUE's "FILE". An embedded CUE
* sheet must always point to the song file it is contained
* sheet must always point to the song file it is contained
...
@@ -63,18 +63,18 @@ struct EmbeddedCuePlaylist {
...
@@ -63,18 +63,18 @@ struct EmbeddedCuePlaylist {
CueParser
*
parser
;
CueParser
*
parser
;
public
:
EmbeddedCuePlaylist
()
EmbeddedCuePlaylist
()
:
filename
(
nullptr
),
cuesheet
(
nullptr
),
parser
(
nullptr
)
{
:
filename
(
nullptr
),
cuesheet
(
nullptr
),
parser
(
nullptr
)
{
playlist_provider_init
(
&
base
,
&
embcue_playlist_plugin
);
}
}
~
EmbeddedCuePlaylist
()
{
virtual
~
EmbeddedCuePlaylist
()
{
delete
parser
;
delete
parser
;
g_free
(
cuesheet
);
g_free
(
cuesheet
);
g_free
(
filename
);
g_free
(
filename
);
}
}
Song
*
Read
()
;
virtual
Song
*
NextSong
()
override
;
};
};
static
void
static
void
...
@@ -93,7 +93,7 @@ static const struct tag_handler embcue_tag_handler = {
...
@@ -93,7 +93,7 @@ static const struct tag_handler embcue_tag_handler = {
embcue_tag_pair
,
embcue_tag_pair
,
};
};
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
embcue_playlist_open_uri
(
const
char
*
uri
,
embcue_playlist_open_uri
(
const
char
*
uri
,
gcc_unused
Mutex
&
mutex
,
gcc_unused
Mutex
&
mutex
,
gcc_unused
Cond
&
cond
)
gcc_unused
Cond
&
cond
)
...
@@ -122,19 +122,11 @@ embcue_playlist_open_uri(const char *uri,
...
@@ -122,19 +122,11 @@ embcue_playlist_open_uri(const char *uri,
playlist
->
next
=
playlist
->
cuesheet
;
playlist
->
next
=
playlist
->
cuesheet
;
playlist
->
parser
=
new
CueParser
();
playlist
->
parser
=
new
CueParser
();
return
&
playlist
->
base
;
return
playlist
;
}
}
static
void
Song
*
embcue_playlist_close
(
struct
playlist_provider
*
_playlist
)
EmbeddedCuePlaylist
::
NextSong
()
{
EmbeddedCuePlaylist
*
playlist
=
(
EmbeddedCuePlaylist
*
)
_playlist
;
delete
playlist
;
}
inline
Song
*
EmbeddedCuePlaylist
::
Read
()
{
{
Song
*
song
=
parser
->
Get
();
Song
*
song
=
parser
->
Get
();
if
(
song
!=
NULL
)
if
(
song
!=
NULL
)
...
@@ -165,14 +157,6 @@ EmbeddedCuePlaylist::Read()
...
@@ -165,14 +157,6 @@ EmbeddedCuePlaylist::Read()
return
song
;
return
song
;
}
}
static
Song
*
embcue_playlist_read
(
struct
playlist_provider
*
_playlist
)
{
EmbeddedCuePlaylist
*
playlist
=
(
EmbeddedCuePlaylist
*
)
_playlist
;
return
playlist
->
Read
();
}
static
const
char
*
const
embcue_playlist_suffixes
[]
=
{
static
const
char
*
const
embcue_playlist_suffixes
[]
=
{
/* a few codecs that are known to be supported; there are
/* a few codecs that are known to be supported; there are
probably many more */
probably many more */
...
@@ -192,8 +176,6 @@ const struct playlist_plugin embcue_playlist_plugin = {
...
@@ -192,8 +176,6 @@ const struct playlist_plugin embcue_playlist_plugin = {
nullptr
,
nullptr
,
embcue_playlist_open_uri
,
embcue_playlist_open_uri
,
nullptr
,
nullptr
,
embcue_playlist_close
,
embcue_playlist_read
,
embcue_playlist_suffixes
,
embcue_playlist_suffixes
,
nullptr
,
nullptr
,
...
...
src/playlist/ExtM3uPlaylistPlugin.cxx
View file @
8929f88e
...
@@ -20,6 +20,7 @@
...
@@ -20,6 +20,7 @@
#include "config.h"
#include "config.h"
#include "ExtM3uPlaylistPlugin.hxx"
#include "ExtM3uPlaylistPlugin.hxx"
#include "PlaylistPlugin.hxx"
#include "PlaylistPlugin.hxx"
#include "SongEnumerator.hxx"
#include "Song.hxx"
#include "Song.hxx"
#include "Tag.hxx"
#include "Tag.hxx"
#include "util/StringUtil.hxx"
#include "util/StringUtil.hxx"
...
@@ -30,40 +31,36 @@
...
@@ -30,40 +31,36 @@
#include <string.h>
#include <string.h>
#include <stdlib.h>
#include <stdlib.h>
struct
ExtM3uPlaylist
{
class
ExtM3uPlaylist
final
:
public
SongEnumerator
{
struct
playlist_provider
base
;
TextInputStream
tis
;
TextInputStream
tis
;
public
:
ExtM3uPlaylist
(
input_stream
*
is
)
ExtM3uPlaylist
(
input_stream
*
is
)
:
tis
(
is
)
{
:
tis
(
is
)
{
playlist_provider_init
(
&
base
,
&
extm3u_playlist_plugin
);
}
}
bool
CheckFirstLine
()
{
std
::
string
line
;
return
tis
.
ReadLine
(
line
)
&&
strcmp
(
line
.
c_str
(),
"#EXTM3U"
)
==
0
;
}
virtual
Song
*
NextSong
()
override
;
};
};
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
extm3u_open_stream
(
struct
input_stream
*
is
)
extm3u_open_stream
(
struct
input_stream
*
is
)
{
{
ExtM3uPlaylist
*
playlist
=
new
ExtM3uPlaylist
(
is
);
ExtM3uPlaylist
*
playlist
=
new
ExtM3uPlaylist
(
is
);
std
::
string
line
;
if
(
!
playlist
->
CheckFirstLine
())
{
if
(
!
playlist
->
tis
.
ReadLine
(
line
)
||
strcmp
(
line
.
c_str
(),
"#EXTM3U"
)
!=
0
)
{
/* no EXTM3U header: fall back to the plain m3u
/* no EXTM3U header: fall back to the plain m3u
plugin */
plugin */
delete
playlist
;
delete
playlist
;
return
NULL
;
return
NULL
;
}
}
return
&
playlist
->
base
;
return
playlist
;
}
static
void
extm3u_close
(
struct
playlist_provider
*
_playlist
)
{
ExtM3uPlaylist
*
playlist
=
(
ExtM3uPlaylist
*
)
_playlist
;
delete
playlist
;
}
}
/**
/**
...
@@ -106,17 +103,16 @@ extm3u_parse_tag(const char *line)
...
@@ -106,17 +103,16 @@ extm3u_parse_tag(const char *line)
return
tag
;
return
tag
;
}
}
static
Song
*
Song
*
extm3u_read
(
struct
playlist_provider
*
_playlist
)
ExtM3uPlaylist
::
NextSong
(
)
{
{
ExtM3uPlaylist
*
playlist
=
(
ExtM3uPlaylist
*
)
_playlist
;
Tag
*
tag
=
NULL
;
Tag
*
tag
=
NULL
;
std
::
string
line
;
std
::
string
line
;
const
char
*
line_s
;
const
char
*
line_s
;
Song
*
song
;
Song
*
song
;
do
{
do
{
if
(
!
playlist
->
tis
.
ReadLine
(
line
))
{
if
(
!
tis
.
ReadLine
(
line
))
{
delete
tag
;
delete
tag
;
return
NULL
;
return
NULL
;
}
}
...
@@ -155,8 +151,6 @@ const struct playlist_plugin extm3u_playlist_plugin = {
...
@@ -155,8 +151,6 @@ const struct playlist_plugin extm3u_playlist_plugin = {
nullptr
,
nullptr
,
nullptr
,
nullptr
,
extm3u_open_stream
,
extm3u_open_stream
,
extm3u_close
,
extm3u_read
,
nullptr
,
nullptr
,
extm3u_suffixes
,
extm3u_suffixes
,
...
...
src/playlist/LastFMPlaylistPlugin.cxx
View file @
8929f88e
...
@@ -21,6 +21,7 @@
...
@@ -21,6 +21,7 @@
#include "LastFMPlaylistPlugin.hxx"
#include "LastFMPlaylistPlugin.hxx"
#include "PlaylistPlugin.hxx"
#include "PlaylistPlugin.hxx"
#include "PlaylistRegistry.hxx"
#include "PlaylistRegistry.hxx"
#include "SongEnumerator.hxx"
#include "ConfigData.hxx"
#include "ConfigData.hxx"
#include "Song.hxx"
#include "Song.hxx"
#include "InputStream.hxx"
#include "InputStream.hxx"
...
@@ -31,22 +32,24 @@
...
@@ -31,22 +32,24 @@
#include <assert.h>
#include <assert.h>
#include <string.h>
#include <string.h>
struct
LastfmPlaylist
{
class
LastfmPlaylist
final
:
public
SongEnumerator
{
struct
playlist_provider
base
;
struct
input_stream
*
is
;
struct
input_stream
*
is
;
struct
playlist_provider
*
xspf
;
SongEnumerator
*
const
xspf
;
LastfmPlaylist
(
input_stream
*
_is
,
playlist_provider
*
_xspf
)
public
:
LastfmPlaylist
(
input_stream
*
_is
,
SongEnumerator
*
_xspf
)
:
is
(
_is
),
xspf
(
_xspf
)
{
:
is
(
_is
),
xspf
(
_xspf
)
{
playlist_provider_init
(
&
base
,
&
lastfm_playlist_plugin
);
}
}
~
LastfmPlaylist
()
{
virtual
~
LastfmPlaylist
()
{
playlist_plugin_close
(
xspf
)
;
delete
xspf
;
is
->
Close
();
is
->
Close
();
}
}
virtual
Song
*
NextSong
()
override
{
return
xspf
->
NextSong
();
}
};
};
static
struct
{
static
struct
{
...
@@ -161,7 +164,7 @@ lastfm_find(const char *response, const char *name)
...
@@ -161,7 +164,7 @@ lastfm_find(const char *response, const char *name)
}
}
}
}
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
lastfm_open_uri
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
)
lastfm_open_uri
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
)
{
{
char
*
p
,
*
q
,
*
response
,
*
session
;
char
*
p
,
*
q
,
*
response
,
*
session
;
...
@@ -256,24 +259,7 @@ lastfm_open_uri(const char *uri, Mutex &mutex, Cond &cond)
...
@@ -256,24 +259,7 @@ lastfm_open_uri(const char *uri, Mutex &mutex, Cond &cond)
/* create the playlist object */
/* create the playlist object */
const
auto
playlist
=
new
LastfmPlaylist
(
is
,
xspf
);
return
new
LastfmPlaylist
(
is
,
xspf
);
return
&
playlist
->
base
;
}
static
void
lastfm_close
(
struct
playlist_provider
*
_playlist
)
{
LastfmPlaylist
*
playlist
=
(
LastfmPlaylist
*
)
_playlist
;
delete
playlist
;
}
static
Song
*
lastfm_read
(
struct
playlist_provider
*
_playlist
)
{
LastfmPlaylist
*
playlist
=
(
LastfmPlaylist
*
)
_playlist
;
return
playlist_plugin_read
(
playlist
->
xspf
);
}
}
static
const
char
*
const
lastfm_schemes
[]
=
{
static
const
char
*
const
lastfm_schemes
[]
=
{
...
@@ -288,8 +274,6 @@ const struct playlist_plugin lastfm_playlist_plugin = {
...
@@ -288,8 +274,6 @@ const struct playlist_plugin lastfm_playlist_plugin = {
lastfm_finish
,
lastfm_finish
,
lastfm_open_uri
,
lastfm_open_uri
,
nullptr
,
nullptr
,
lastfm_close
,
lastfm_read
,
lastfm_schemes
,
lastfm_schemes
,
nullptr
,
nullptr
,
...
...
src/playlist/M3uPlaylistPlugin.cxx
View file @
8929f88e
...
@@ -20,47 +20,37 @@
...
@@ -20,47 +20,37 @@
#include "config.h"
#include "config.h"
#include "M3uPlaylistPlugin.hxx"
#include "M3uPlaylistPlugin.hxx"
#include "PlaylistPlugin.hxx"
#include "PlaylistPlugin.hxx"
#include "SongEnumerator.hxx"
#include "Song.hxx"
#include "Song.hxx"
#include "TextInputStream.hxx"
#include "TextInputStream.hxx"
#include <glib.h>
#include <glib.h>
struct
M3uPlaylist
{
class
M3uPlaylist
final
:
public
SongEnumerator
{
struct
playlist_provider
base
;
TextInputStream
tis
;
TextInputStream
tis
;
public
:
M3uPlaylist
(
input_stream
*
is
)
M3uPlaylist
(
input_stream
*
is
)
:
tis
(
is
)
{
:
tis
(
is
)
{
playlist_provider_init
(
&
base
,
&
m3u_playlist_plugin
);
}
}
virtual
Song
*
NextSong
()
override
;
};
};
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
m3u_open_stream
(
struct
input_stream
*
is
)
m3u_open_stream
(
struct
input_stream
*
is
)
{
{
M3uPlaylist
*
playlist
=
new
M3uPlaylist
(
is
);
return
new
M3uPlaylist
(
is
);
return
&
playlist
->
base
;
}
static
void
m3u_close
(
struct
playlist_provider
*
_playlist
)
{
M3uPlaylist
*
playlist
=
(
M3uPlaylist
*
)
_playlist
;
delete
playlist
;
}
}
static
Song
*
Song
*
m3u_read
(
struct
playlist_provider
*
_playlist
)
M3uPlaylist
::
NextSong
(
)
{
{
M3uPlaylist
*
playlist
=
(
M3uPlaylist
*
)
_playlist
;
std
::
string
line
;
std
::
string
line
;
const
char
*
line_s
;
const
char
*
line_s
;
do
{
do
{
if
(
!
playlist
->
tis
.
ReadLine
(
line
))
if
(
!
tis
.
ReadLine
(
line
))
return
NULL
;
return
NULL
;
line_s
=
line
.
c_str
();
line_s
=
line
.
c_str
();
...
@@ -89,8 +79,6 @@ const struct playlist_plugin m3u_playlist_plugin = {
...
@@ -89,8 +79,6 @@ const struct playlist_plugin m3u_playlist_plugin = {
nullptr
,
nullptr
,
nullptr
,
nullptr
,
m3u_open_stream
,
m3u_open_stream
,
m3u_close
,
m3u_read
,
nullptr
,
nullptr
,
m3u_suffixes
,
m3u_suffixes
,
...
...
src/playlist/PlsPlaylistPlugin.cxx
View file @
8929f88e
...
@@ -19,7 +19,8 @@
...
@@ -19,7 +19,8 @@
#include "config.h"
#include "config.h"
#include "PlsPlaylistPlugin.hxx"
#include "PlsPlaylistPlugin.hxx"
#include "MemoryPlaylistProvider.hxx"
#include "PlaylistPlugin.hxx"
#include "MemorySongEnumerator.hxx"
#include "InputStream.hxx"
#include "InputStream.hxx"
#include "Song.hxx"
#include "Song.hxx"
#include "Tag.hxx"
#include "Tag.hxx"
...
@@ -101,7 +102,7 @@ pls_parser(GKeyFile *keyfile, std::forward_list<SongPointer> &songs)
...
@@ -101,7 +102,7 @@ pls_parser(GKeyFile *keyfile, std::forward_list<SongPointer> &songs)
}
}
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
pls_open_stream
(
struct
input_stream
*
is
)
pls_open_stream
(
struct
input_stream
*
is
)
{
{
GError
*
error
=
NULL
;
GError
*
error
=
NULL
;
...
@@ -150,7 +151,7 @@ pls_open_stream(struct input_stream *is)
...
@@ -150,7 +151,7 @@ pls_open_stream(struct input_stream *is)
g_key_file_free
(
keyfile
);
g_key_file_free
(
keyfile
);
songs
.
reverse
();
songs
.
reverse
();
return
new
Memory
PlaylistProvide
r
(
std
::
move
(
songs
));
return
new
Memory
SongEnumerato
r
(
std
::
move
(
songs
));
}
}
static
const
char
*
const
pls_suffixes
[]
=
{
static
const
char
*
const
pls_suffixes
[]
=
{
...
@@ -170,8 +171,6 @@ const struct playlist_plugin pls_playlist_plugin = {
...
@@ -170,8 +171,6 @@ const struct playlist_plugin pls_playlist_plugin = {
nullptr
,
nullptr
,
nullptr
,
nullptr
,
pls_open_stream
,
pls_open_stream
,
nullptr
,
nullptr
,
nullptr
,
nullptr
,
pls_suffixes
,
pls_suffixes
,
...
...
src/playlist/RssPlaylistPlugin.cxx
View file @
8929f88e
...
@@ -19,7 +19,8 @@
...
@@ -19,7 +19,8 @@
#include "config.h"
#include "config.h"
#include "RssPlaylistPlugin.hxx"
#include "RssPlaylistPlugin.hxx"
#include "MemoryPlaylistProvider.hxx"
#include "PlaylistPlugin.hxx"
#include "MemorySongEnumerator.hxx"
#include "InputStream.hxx"
#include "InputStream.hxx"
#include "Song.hxx"
#include "Song.hxx"
#include "Tag.hxx"
#include "Tag.hxx"
...
@@ -198,7 +199,7 @@ rss_parser_destroy(gpointer data)
...
@@ -198,7 +199,7 @@ rss_parser_destroy(gpointer data)
*
*
*/
*/
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
rss_open_stream
(
struct
input_stream
*
is
)
rss_open_stream
(
struct
input_stream
*
is
)
{
{
RssParser
parser
;
RssParser
parser
;
...
@@ -246,8 +247,8 @@ rss_open_stream(struct input_stream *is)
...
@@ -246,8 +247,8 @@ rss_open_stream(struct input_stream *is)
}
}
parser
.
songs
.
reverse
();
parser
.
songs
.
reverse
();
Memory
PlaylistProvide
r
*
playlist
=
Memory
SongEnumerato
r
*
playlist
=
new
Memory
PlaylistProvide
r
(
std
::
move
(
parser
.
songs
));
new
Memory
SongEnumerato
r
(
std
::
move
(
parser
.
songs
));
g_markup_parse_context_free
(
context
);
g_markup_parse_context_free
(
context
);
...
@@ -272,8 +273,6 @@ const struct playlist_plugin rss_playlist_plugin = {
...
@@ -272,8 +273,6 @@ const struct playlist_plugin rss_playlist_plugin = {
nullptr
,
nullptr
,
nullptr
,
nullptr
,
rss_open_stream
,
rss_open_stream
,
nullptr
,
nullptr
,
nullptr
,
nullptr
,
rss_suffixes
,
rss_suffixes
,
...
...
src/playlist/SoundCloudPlaylistPlugin.cxx
View file @
8929f88e
...
@@ -19,7 +19,8 @@
...
@@ -19,7 +19,8 @@
#include "config.h"
#include "config.h"
#include "SoundCloudPlaylistPlugin.hxx"
#include "SoundCloudPlaylistPlugin.hxx"
#include "MemoryPlaylistProvider.hxx"
#include "PlaylistPlugin.hxx"
#include "MemorySongEnumerator.hxx"
#include "ConfigData.hxx"
#include "ConfigData.hxx"
#include "InputStream.hxx"
#include "InputStream.hxx"
#include "Song.hxx"
#include "Song.hxx"
...
@@ -315,7 +316,7 @@ soundcloud_parse_json(const char *url, yajl_handle hand,
...
@@ -315,7 +316,7 @@ soundcloud_parse_json(const char *url, yajl_handle hand,
* soundcloud://url/<url or path of soundcloud page>
* soundcloud://url/<url or path of soundcloud page>
*/
*/
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
soundcloud_open_uri
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
)
soundcloud_open_uri
(
const
char
*
uri
,
Mutex
&
mutex
,
Cond
&
cond
)
{
{
char
*
s
,
*
p
;
char
*
s
,
*
p
;
...
@@ -389,7 +390,7 @@ soundcloud_open_uri(const char *uri, Mutex &mutex, Cond &cond)
...
@@ -389,7 +390,7 @@ soundcloud_open_uri(const char *uri, Mutex &mutex, Cond &cond)
return
NULL
;
return
NULL
;
data
.
songs
.
reverse
();
data
.
songs
.
reverse
();
return
new
Memory
PlaylistProvide
r
(
std
::
move
(
data
.
songs
));
return
new
Memory
SongEnumerato
r
(
std
::
move
(
data
.
songs
));
}
}
static
const
char
*
const
soundcloud_schemes
[]
=
{
static
const
char
*
const
soundcloud_schemes
[]
=
{
...
@@ -404,8 +405,6 @@ const struct playlist_plugin soundcloud_playlist_plugin = {
...
@@ -404,8 +405,6 @@ const struct playlist_plugin soundcloud_playlist_plugin = {
soundcloud_finish
,
soundcloud_finish
,
soundcloud_open_uri
,
soundcloud_open_uri
,
nullptr
,
nullptr
,
nullptr
,
nullptr
,
soundcloud_schemes
,
soundcloud_schemes
,
nullptr
,
nullptr
,
...
...
src/playlist/XspfPlaylistPlugin.cxx
View file @
8929f88e
...
@@ -19,7 +19,8 @@
...
@@ -19,7 +19,8 @@
#include "config.h"
#include "config.h"
#include "XspfPlaylistPlugin.hxx"
#include "XspfPlaylistPlugin.hxx"
#include "MemoryPlaylistProvider.hxx"
#include "PlaylistPlugin.hxx"
#include "MemorySongEnumerator.hxx"
#include "InputStream.hxx"
#include "InputStream.hxx"
#include "Tag.hxx"
#include "Tag.hxx"
#include "util/Error.hxx"
#include "util/Error.hxx"
...
@@ -217,7 +218,7 @@ xspf_parser_destroy(gpointer data)
...
@@ -217,7 +218,7 @@ xspf_parser_destroy(gpointer data)
*
*
*/
*/
static
struct
playlist_provide
r
*
static
SongEnumerato
r
*
xspf_open_stream
(
struct
input_stream
*
is
)
xspf_open_stream
(
struct
input_stream
*
is
)
{
{
XspfParser
parser
;
XspfParser
parser
;
...
@@ -265,8 +266,8 @@ xspf_open_stream(struct input_stream *is)
...
@@ -265,8 +266,8 @@ xspf_open_stream(struct input_stream *is)
}
}
parser
.
songs
.
reverse
();
parser
.
songs
.
reverse
();
Memory
PlaylistProvide
r
*
playlist
=
Memory
SongEnumerato
r
*
playlist
=
new
Memory
PlaylistProvide
r
(
std
::
move
(
parser
.
songs
));
new
Memory
SongEnumerato
r
(
std
::
move
(
parser
.
songs
));
g_markup_parse_context_free
(
context
);
g_markup_parse_context_free
(
context
);
...
@@ -290,8 +291,6 @@ const struct playlist_plugin xspf_playlist_plugin = {
...
@@ -290,8 +291,6 @@ const struct playlist_plugin xspf_playlist_plugin = {
nullptr
,
nullptr
,
nullptr
,
nullptr
,
xspf_open_stream
,
xspf_open_stream
,
nullptr
,
nullptr
,
nullptr
,
nullptr
,
xspf_suffixes
,
xspf_suffixes
,
...
...
test/dump_playlist.cxx
View file @
8929f88e
...
@@ -20,6 +20,7 @@
...
@@ -20,6 +20,7 @@
#include "config.h"
#include "config.h"
#include "TagSave.hxx"
#include "TagSave.hxx"
#include "Song.hxx"
#include "Song.hxx"
#include "SongEnumerator.hxx"
#include "Directory.hxx"
#include "Directory.hxx"
#include "InputStream.hxx"
#include "InputStream.hxx"
#include "ConfigGlobal.hxx"
#include "ConfigGlobal.hxx"
...
@@ -141,7 +142,6 @@ int main(int argc, char **argv)
...
@@ -141,7 +142,6 @@ int main(int argc, char **argv)
{
{
const
char
*
uri
;
const
char
*
uri
;
struct
input_stream
*
is
=
NULL
;
struct
input_stream
*
is
=
NULL
;
struct
playlist_provider
*
playlist
;
Song
*
song
;
Song
*
song
;
if
(
argc
!=
3
)
{
if
(
argc
!=
3
)
{
...
@@ -186,7 +186,7 @@ int main(int argc, char **argv)
...
@@ -186,7 +186,7 @@ int main(int argc, char **argv)
Mutex
mutex
;
Mutex
mutex
;
Cond
cond
;
Cond
cond
;
playlist
=
playlist_list_open_uri
(
uri
,
mutex
,
cond
);
auto
playlist
=
playlist_list_open_uri
(
uri
,
mutex
,
cond
);
if
(
playlist
==
NULL
)
{
if
(
playlist
==
NULL
)
{
/* open the stream and wait until it becomes ready */
/* open the stream and wait until it becomes ready */
...
@@ -213,7 +213,7 @@ int main(int argc, char **argv)
...
@@ -213,7 +213,7 @@ int main(int argc, char **argv)
/* dump the playlist */
/* dump the playlist */
while
((
song
=
playlist
_plugin_read
(
playlist
))
!=
NULL
)
{
while
((
song
=
playlist
->
NextSong
(
))
!=
NULL
)
{
g_print
(
"%s
\n
"
,
song
->
uri
);
g_print
(
"%s
\n
"
,
song
->
uri
);
if
(
song
->
end_ms
>
0
)
if
(
song
->
end_ms
>
0
)
...
@@ -235,7 +235,7 @@ int main(int argc, char **argv)
...
@@ -235,7 +235,7 @@ int main(int argc, char **argv)
/* deinitialize everything */
/* deinitialize everything */
playlist_plugin_close
(
playlist
)
;
delete
playlist
;
if
(
is
!=
NULL
)
if
(
is
!=
NULL
)
is
->
Close
();
is
->
Close
();
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment