diff options
author | Michael Roitzsch <mroi@users.sourceforge.net> | 2004-06-08 20:44:27 +0000 |
---|---|---|
committer | Michael Roitzsch <mroi@users.sourceforge.net> | 2004-06-08 20:44:27 +0000 |
commit | 169715ef3e057ba83db5307c799e5b8543cc5d46 (patch) | |
tree | 212fd570b67cb050011f311a8faa9cd8ebcbdb37 /src/xine-engine/load_plugins.c | |
parent | 8afb108e2d6beab74685b610ba5295b56fa77d23 (diff) | |
download | xine-lib-169715ef3e057ba83db5307c799e5b8543cc5d46.tar.gz xine-lib-169715ef3e057ba83db5307c799e5b8543cc5d46.tar.bz2 |
a better approach to the module unload prevention
(when this works in OSX, we can remove the PLUGIN_NO_UNLOAD flag from
video_out_macosx.m, but the support for this in the plugin loader seems
to be a good idea anyway)
CVS patchset: 6661
CVS date: 2004/06/08 20:44:27
Diffstat (limited to 'src/xine-engine/load_plugins.c')
-rw-r--r-- | src/xine-engine/load_plugins.c | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/src/xine-engine/load_plugins.c b/src/xine-engine/load_plugins.c index b7db9fc85..0a73283a7 100644 --- a/src/xine-engine/load_plugins.c +++ b/src/xine-engine/load_plugins.c @@ -17,7 +17,7 @@ * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA * - * $Id: load_plugins.c,v 1.177 2004/06/05 16:06:13 jcdutton Exp $ + * $Id: load_plugins.c,v 1.178 2004/06/08 20:44:27 mroi Exp $ * * * Load input/demux/audio_out/video_out/codec plugins @@ -511,6 +511,7 @@ static void collect_plugins(xine_t *this, char *path){ _("load_plugins: cannot open plugin lib %s:\n%s\n"), str, error); } else { + int do_not_unload = 0; if (info || (info = dlsym(lib, "xine_plugin_info"))) { @@ -569,6 +570,7 @@ static void collect_plugins(xine_t *this, char *path){ /* get next info either from lib or cache */ if( lib ) { info++; + do_not_unload = (do_not_unload || (info->type & PLUGIN_NO_UNLOAD)); } else { info = _get_cached_plugin ( this->plugin_catalog->cache, @@ -582,11 +584,8 @@ static void collect_plugins(xine_t *this, char *path){ xine_log (this, XINE_LOG_PLUGIN, _("load_plugins: can't get plugin info from %s:\n%s\n"), str, error); } - if( lib ) -#ifdef HOST_OS_DARWIN - if (dlsym (lib, "plugin_contains_objc_code") == NULL) -#endif - dlclose(lib); + if( lib && !do_not_unload ) + dlclose(lib); } break; case S_IFDIR: |