X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=include%2Fvlc_modules.h;h=7d965bcd11ced7fdc71ac0ca6fa6afaef86a6331;hb=6a66117a34f627ad9560b07cead07663b48f23b6;hp=20509091b7ce515356dab116c339a37ed15f34f7;hpb=df61d33b06e2b3cbbe746b2f5a9bea5b370c24ff;p=vlc diff --git a/include/vlc_modules.h b/include/vlc_modules.h index 20509091b7..7d965bcd11 100644 --- a/include/vlc_modules.h +++ b/include/vlc_modules.h @@ -21,13 +21,10 @@ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. *****************************************************************************/ -#if !defined( __LIBVLC__ ) - #error You are not libvlc or one of its plugins. You cannot include this file -#endif - /***************************************************************************** * Exported functions. *****************************************************************************/ + #define module_Need(a,b,c,d) __module_Need(VLC_OBJECT(a),b,c,d) VLC_EXPORT( module_t *, __module_Need, ( vlc_object_t *, const char *, const char *, bool ) ); #define module_Unneed(a,b) __module_Unneed(VLC_OBJECT(a),b) @@ -42,7 +39,6 @@ VLC_EXPORT( void, module_Put, ( module_t *module ) ); VLC_EXPORT( module_config_t *, module_GetConfig, ( const module_t *, unsigned * ) ); VLC_EXPORT( void, module_PutConfig, ( module_config_t * ) ); - /* Return a NULL terminated array with the names of the modules that have a * certain capability. * Free after uses both the string and the table. */ @@ -52,30 +48,20 @@ VLC_EXPORT(char **, __module_GetModulesNamesForCapability, ( vlc_object_t *p_this, const char * psz_capability, char ***psz_longname ) ); -VLC_EXPORT( module_t *, vlc_module_create, ( vlc_object_t * ) ); -VLC_EXPORT( module_t *, vlc_submodule_create, ( module_t * ) ); -VLC_EXPORT( int, vlc_module_set, (module_t *module, int propid, void *value) ); - -enum vlc_module_properties -{ - /* DO NOT EVER REMOVE, INSERT OR REPLACE ANY ITEM! It would break the ABI! - * Append new items at the end ONLY. */ - VLC_MODULE_CPU_REQUIREMENT, - VLC_MODULE_SHORTCUT, - VLC_MODULE_SHORTNAME, - VLC_MODULE_DESCRIPTION, - VLC_MODULE_HELP, - VLC_MODULE_CAPABILITY, - VLC_MODULE_SCORE, - VLC_MODULE_PROGRAM, - VLC_MODULE_CB_OPEN, - VLC_MODULE_CB_CLOSE, - VLC_MODULE_UNLOADABLE, - VLC_MODULE_NAME, -}; - VLC_EXPORT( bool, module_IsCapable, ( const module_t *m, const char *cap ) ); VLC_EXPORT( const char *, module_GetObjName, ( const module_t *m ) ); VLC_EXPORT( const char *, module_GetName, ( const module_t *m, bool long_name ) ); #define module_GetLongName( m ) module_GetName( m, true ) VLC_EXPORT( const char *, module_GetHelp, ( const module_t *m ) ); + + +#define module_GetMainModule(a) __module_GetMainModule(VLC_OBJECT(a)) +static inline module_t * __module_GetMainModule( vlc_object_t * p_this ) +{ + return module_Find( p_this, "main" ); +} + +static inline bool module_IsMainModule( const module_t * p_module ) +{ + return !strcmp( module_GetObjName( p_module ), "main" ); +}