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
c128f2dd
Commit
c128f2dd
authored
Dec 16, 2009
by
Max Kellermann
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
playlist_list: support URI suffix match
When no plugin matches the URI scheme, try the file name suffix.
parent
843717d2
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
54 additions
and
2 deletions
+54
-2
playlist_list.c
src/playlist_list.c
+54
-2
No files found.
src/playlist_list.c
View file @
c128f2dd
...
@@ -116,8 +116,8 @@ g_uri_parse_scheme(const char *uri)
...
@@ -116,8 +116,8 @@ g_uri_parse_scheme(const char *uri)
}
}
#endif
#endif
struct
playlist_provider
*
st
atic
st
ruct
playlist_provider
*
playlist_list_open_uri
(
const
char
*
uri
)
playlist_list_open_uri
_scheme
(
const
char
*
uri
,
bool
*
tried
)
{
{
char
*
scheme
;
char
*
scheme
;
struct
playlist_provider
*
playlist
=
NULL
;
struct
playlist_provider
*
playlist
=
NULL
;
...
@@ -131,12 +131,16 @@ playlist_list_open_uri(const char *uri)
...
@@ -131,12 +131,16 @@ playlist_list_open_uri(const char *uri)
for
(
unsigned
i
=
0
;
playlist_plugins
[
i
]
!=
NULL
;
++
i
)
{
for
(
unsigned
i
=
0
;
playlist_plugins
[
i
]
!=
NULL
;
++
i
)
{
const
struct
playlist_plugin
*
plugin
=
playlist_plugins
[
i
];
const
struct
playlist_plugin
*
plugin
=
playlist_plugins
[
i
];
assert
(
!
tried
[
i
]);
if
(
playlist_plugins_enabled
[
i
]
&&
plugin
->
open_uri
!=
NULL
&&
if
(
playlist_plugins_enabled
[
i
]
&&
plugin
->
open_uri
!=
NULL
&&
plugin
->
schemes
!=
NULL
&&
plugin
->
schemes
!=
NULL
&&
string_array_contains
(
plugin
->
schemes
,
scheme
))
{
string_array_contains
(
plugin
->
schemes
,
scheme
))
{
playlist
=
playlist_plugin_open_uri
(
plugin
,
uri
);
playlist
=
playlist_plugin_open_uri
(
plugin
,
uri
);
if
(
playlist
!=
NULL
)
if
(
playlist
!=
NULL
)
break
;
break
;
tried
[
i
]
=
true
;
}
}
}
}
...
@@ -145,6 +149,54 @@ playlist_list_open_uri(const char *uri)
...
@@ -145,6 +149,54 @@ playlist_list_open_uri(const char *uri)
}
}
static
struct
playlist_provider
*
static
struct
playlist_provider
*
playlist_list_open_uri_suffix
(
const
char
*
uri
,
const
bool
*
tried
)
{
const
char
*
suffix
;
struct
playlist_provider
*
playlist
=
NULL
;
assert
(
uri
!=
NULL
);
suffix
=
strrchr
(
uri
,
'.'
);
if
(
suffix
==
NULL
||
strchr
(
suffix
,
'/'
)
!=
NULL
)
return
NULL
;
++
suffix
;
for
(
unsigned
i
=
0
;
playlist_plugins
[
i
]
!=
NULL
;
++
i
)
{
const
struct
playlist_plugin
*
plugin
=
playlist_plugins
[
i
];
if
(
playlist_plugins_enabled
[
i
]
&&
!
tried
[
i
]
&&
plugin
->
open_uri
!=
NULL
&&
plugin
->
suffixes
!=
NULL
&&
string_array_contains
(
plugin
->
suffixes
,
suffix
))
{
playlist
=
playlist_plugin_open_uri
(
plugin
,
uri
);
if
(
playlist
!=
NULL
)
break
;
}
}
return
playlist
;
}
struct
playlist_provider
*
playlist_list_open_uri
(
const
char
*
uri
)
{
struct
playlist_provider
*
playlist
;
/** this array tracks which plugins have already been tried by
playlist_list_open_uri_scheme() */
bool
tried
[
G_N_ELEMENTS
(
playlist_plugins
)
-
1
];
assert
(
uri
!=
NULL
);
memset
(
tried
,
false
,
sizeof
(
tried
));
playlist
=
playlist_list_open_uri_scheme
(
uri
,
tried
);
if
(
playlist
==
NULL
)
playlist
=
playlist_list_open_uri_suffix
(
uri
,
tried
);
return
playlist
;
}
static
struct
playlist_provider
*
playlist_list_open_stream_mime
(
struct
input_stream
*
is
)
playlist_list_open_stream_mime
(
struct
input_stream
*
is
)
{
{
struct
playlist_provider
*
playlist
;
struct
playlist_provider
*
playlist
;
...
...
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