diff options
author | Alexey Yakovenko <waker@users.sourceforge.net> | 2014-06-24 20:15:12 +0200 |
---|---|---|
committer | Alexey Yakovenko <waker@users.sourceforge.net> | 2014-06-24 20:15:12 +0200 |
commit | 9c544c03c095115dce261b928334cdf81ae34203 (patch) | |
tree | b11e8f0eb22ccab799fc5b63ce8fbe5cbbc96a3f /plugins | |
parent | 8c9370dc472a9abf272894872da22452bdf5b018 (diff) |
wma: use the new open2 API to make it possible to interrupt hanging streams without blocking on "init"
Diffstat (limited to 'plugins')
-rw-r--r-- | plugins/wma/wma_plugin.c | 26 |
1 files changed, 24 insertions, 2 deletions
diff --git a/plugins/wma/wma_plugin.c b/plugins/wma/wma_plugin.c index 71c70a2e..8bee83e2 100644 --- a/plugins/wma/wma_plugin.c +++ b/plugins/wma/wma_plugin.c @@ -63,6 +63,7 @@ typedef struct { int skipsamples; char buffer[200000]; // can't predict its size, so set to max int remaining; + int open2_was_used; } wmaplug_info_t; // allocate codec control structure @@ -71,6 +72,23 @@ wmaplug_open (uint32_t hints) { DB_fileinfo_t *_info = malloc (sizeof (wmaplug_info_t)); wmaplug_info_t *info = (wmaplug_info_t *)_info; memset (info, 0, sizeof (wmaplug_info_t)); + + return _info; +} + +static DB_fileinfo_t * +wmaplug_open2 (uint32_t hints, DB_playItem_t *it) { + DB_FILE *file = deadbeef->fopen (deadbeef->pl_find_meta (it, ":URI")); + if (!file) { + return NULL; + } + + DB_fileinfo_t *_info = malloc (sizeof (wmaplug_info_t)); + wmaplug_info_t *info = (wmaplug_info_t *)_info; + memset (info, 0, sizeof (wmaplug_info_t)); + info->open2_was_used = 1; + info->info.file = file; + return _info; } @@ -80,7 +98,10 @@ static int wmaplug_init (DB_fileinfo_t *_info, DB_playItem_t *it) { wmaplug_info_t *info = (wmaplug_info_t *)_info; - info->info.file = deadbeef->fopen (deadbeef->pl_find_meta (it, ":URI")); + if (!info->open2_was_used) { + info->info.file = deadbeef->fopen (deadbeef->pl_find_meta (it, ":URI")); + } + if (!info->info.file) { return -1; } @@ -457,7 +478,7 @@ static const char * exts[] = { "wma", NULL }; // define plugin interface static DB_decoder_t plugin = { .plugin.api_vmajor = 1, - .plugin.api_vminor = 0, + .plugin.api_vminor = 7, .plugin.version_major = 1, .plugin.version_minor = 0, .plugin.type = DB_PLUGIN_DECODER, @@ -489,6 +510,7 @@ static DB_decoder_t plugin = { , .plugin.website = "http://deadbeef.sf.net", .open = wmaplug_open, + .open2 = wmaplug_open2, .init = wmaplug_init, .free = wmaplug_free, .read = wmaplug_read, |