input_stream: let the implementation assign is->plugin
This way, plugins can manipulate the plugin pointer during open().
This commit is contained in:
parent
297101c3f8
commit
dc1cc7e7e5
@ -87,6 +87,7 @@ input_archive_open(struct input_stream *is, const char *pathname)
|
|||||||
is->plugin = &input_plugin_archive;
|
is->plugin = &input_plugin_archive;
|
||||||
|
|
||||||
//internal handle
|
//internal handle
|
||||||
|
is->plugin = &input_plugin_archive;
|
||||||
is->data = arch_ctx;
|
is->data = arch_ctx;
|
||||||
|
|
||||||
//open archive
|
//open archive
|
||||||
|
@ -909,6 +909,7 @@ input_curl_open(struct input_stream *is, const char *url)
|
|||||||
c->buffers = g_queue_new();
|
c->buffers = g_queue_new();
|
||||||
c->rewind = g_queue_new();
|
c->rewind = g_queue_new();
|
||||||
|
|
||||||
|
is->plugin = &input_plugin_curl;
|
||||||
is->data = c;
|
is->data = c;
|
||||||
|
|
||||||
c->multi = curl_multi_init();
|
c->multi = curl_multi_init();
|
||||||
|
@ -62,6 +62,7 @@ input_file_open(struct input_stream *is, const char *filename)
|
|||||||
posix_fadvise(fd, (off_t)0, is->size, POSIX_FADV_SEQUENTIAL);
|
posix_fadvise(fd, (off_t)0, is->size, POSIX_FADV_SEQUENTIAL);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
is->plugin = &input_plugin_file;
|
||||||
is->data = GINT_TO_POINTER(fd);
|
is->data = GINT_TO_POINTER(fd);
|
||||||
is->ready = true;
|
is->ready = true;
|
||||||
|
|
||||||
|
@ -80,7 +80,13 @@ input_stream_open(struct input_stream *is, const char *url)
|
|||||||
const struct input_plugin *plugin = input_plugins[i];
|
const struct input_plugin *plugin = input_plugins[i];
|
||||||
|
|
||||||
if (plugin->open(is, url)) {
|
if (plugin->open(is, url)) {
|
||||||
is->plugin = plugin;
|
assert(is->plugin != NULL);
|
||||||
|
assert(is->plugin->open == NULL ||
|
||||||
|
is->plugin == plugin);
|
||||||
|
assert(is->plugin->close != NULL);
|
||||||
|
assert(is->plugin->read != NULL);
|
||||||
|
assert(is->plugin->eof != NULL);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user