]> git.sesse.net Git - vlc/blobdiff - include/vlc_modules.h
Fix seeking with broken file or without index (close #1687)
[vlc] / include / vlc_modules.h
index c1d370373eac2cfba3e6979227cedddcb96f1b66..7d965bcd11ced7fdc71ac0ca6fa6afaef86a6331 100644 (file)
@@ -24,6 +24,7 @@
 /*****************************************************************************
  * 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)
@@ -38,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. */
@@ -53,3 +53,15 @@ 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" );
+}