Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-2-2
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc-2-2
Commits
92290c9d
Commit
92290c9d
authored
Nov 22, 2006
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Attempt to fix C++ compilation
parent
51ae5f27
Changes
8
Hide whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
81 additions
and
91 deletions
+81
-91
include/configuration.h
include/configuration.h
+3
-4
include/modules.h
include/modules.h
+1
-0
include/modules_inner.h
include/modules_inner.h
+11
-18
include/vlc_symbols.h
include/vlc_symbols.h
+3
-4
src/libvlc-common.c
src/libvlc-common.c
+7
-7
src/libvlc.h
src/libvlc.h
+1
-2
src/misc/configuration.c
src/misc/configuration.c
+41
-44
src/misc/modules.c
src/misc/modules.c
+14
-12
No files found.
include/configuration.h
View file @
92290c9d
...
@@ -30,7 +30,6 @@
...
@@ -30,7 +30,6 @@
/* Configuration hint types */
/* Configuration hint types */
#define CONFIG_HINT_END 0x0001
/* End of config */
#define CONFIG_HINT_CATEGORY 0x0002
/* Start of new category */
#define CONFIG_HINT_CATEGORY 0x0002
/* Start of new category */
#define CONFIG_HINT_SUBCATEGORY 0x0003
/* Start of sub-category */
#define CONFIG_HINT_SUBCATEGORY 0x0003
/* Start of sub-category */
#define CONFIG_HINT_SUBCATEGORY_END 0x0004
/* End of sub-category */
#define CONFIG_HINT_SUBCATEGORY_END 0x0004
/* End of sub-category */
...
@@ -227,11 +226,11 @@ VLC_EXPORT( void, __config_ResetAll, ( vlc_object_t * ) );
...
@@ -227,11 +226,11 @@ VLC_EXPORT( void, __config_ResetAll, ( vlc_object_t * ) );
VLC_EXPORT
(
module_config_t
*
,
config_FindConfig
,(
vlc_object_t
*
,
const
char
*
)
);
VLC_EXPORT
(
module_config_t
*
,
config_FindConfig
,(
vlc_object_t
*
,
const
char
*
)
);
VLC_EXPORT
(
module_t
*
,
config_FindModule
,(
vlc_object_t
*
,
const
char
*
)
);
VLC_EXPORT
(
module_t
*
,
config_FindModule
,(
vlc_object_t
*
,
const
char
*
)
);
VLC_EXPORT
(
void
,
config_Duplicate
,
(
module_t
*
,
const
module_config_t
*
)
);
VLC_EXPORT
(
int
,
config_Duplicate
,
(
module_t
*
,
const
module_config_t
*
,
size_t
)
);
void
config_Free
(
module_t
*
);
void
config_Free
(
module_t
*
);
VLC_EXPORT
(
void
,
config_SetCallbacks
,
(
module_config_t
*
,
module_config_t
*
)
);
VLC_EXPORT
(
void
,
config_SetCallbacks
,
(
module_config_t
*
,
module_config_t
*
,
size_t
)
);
VLC_EXPORT
(
void
,
config_UnsetCallbacks
,
(
module_config_t
*
)
);
VLC_EXPORT
(
void
,
config_UnsetCallbacks
,
(
module_config_t
*
,
size_t
)
);
#define config_GetType(a,b) __config_GetType(VLC_OBJECT(a),b)
#define config_GetType(a,b) __config_GetType(VLC_OBJECT(a),b)
#define config_GetInt(a,b) __config_GetInt(VLC_OBJECT(a),b)
#define config_GetInt(a,b) __config_GetInt(VLC_OBJECT(a),b)
...
...
include/modules.h
View file @
92290c9d
...
@@ -112,6 +112,7 @@ struct module_t
...
@@ -112,6 +112,7 @@ struct module_t
* Variables set by the module to store its config options
* Variables set by the module to store its config options
*/
*/
module_config_t
*
p_config
;
/* Module configuration structure */
module_config_t
*
p_config
;
/* Module configuration structure */
size_t
confsize
;
/* Number of module_config_t items */
unsigned
int
i_config_items
;
/* number of configuration items */
unsigned
int
i_config_items
;
/* number of configuration items */
unsigned
int
i_bool_items
;
/* number of bool config items */
unsigned
int
i_bool_items
;
/* number of bool config items */
...
...
include/modules_inner.h
View file @
92290c9d
...
@@ -102,10 +102,9 @@ E_(vlc_entry) ( module_t *p_module );
...
@@ -102,10 +102,9 @@ E_(vlc_entry) ( module_t *p_module );
EXTERN_SYMBOL DLL_SYMBOL int CDECL_SYMBOL \
EXTERN_SYMBOL DLL_SYMBOL int CDECL_SYMBOL \
__VLC_SYMBOL(vlc_entry) ( module_t *p_module ) \
__VLC_SYMBOL(vlc_entry) ( module_t *p_module ) \
{ \
{ \
int i_shortcut = 1, i_config = -1; \
int i_shortcut = 1; \
size_t i_config = (size_t)(-1); \
module_config_t *p_config = NULL; \
module_config_t *p_config = NULL; \
static const module_config_t config_end = { \
.i_type = CONFIG_HINT_END }; \
STORE_SYMBOLS; \
STORE_SYMBOLS; \
p_module->b_submodule = VLC_FALSE; \
p_module->b_submodule = VLC_FALSE; \
p_module->b_unloadable = VLC_TRUE; \
p_module->b_unloadable = VLC_TRUE; \
...
@@ -127,27 +126,21 @@ E_(vlc_entry) ( module_t *p_module );
...
@@ -127,27 +126,21 @@ E_(vlc_entry) ( module_t *p_module );
#define vlc_module_end( ) \
#define vlc_module_end( ) \
p_submodule->pp_shortcuts[ i_shortcut ] = NULL; \
p_submodule->pp_shortcuts[ i_shortcut ] = NULL; \
} \
} \
if( p_config ) \
if (config_Duplicate( p_module, p_config, ++i_config )) \
return VLC_ENOMEM; \
for( size_t i = 0; i < i_config; i++ ) \
{ \
{ \
int i; \
if( p_config[ i ].i_action ) \
p_config[ ++i_config ] = config_end; \
config_Duplicate( p_module, p_config ); \
for( i = 0; i < i_config; i++ ) \
{ \
{ \
if( p_config[ i ].i_action ) \
free( p_config[ i ].ppf_action ); \
{ \
free( p_config[ i ].ppsz_action_text ); \
free( p_config[ i ].ppf_action ); \
free( p_config[ i ].ppsz_action_text ); \
} \
} \
} \
free( p_config ); \
} \
} \
else config_Duplicate( p_module, &config_end );
\
free( p_config );
\
if( p_module->p_config == NULL ) \
if( p_module->p_config == NULL ) \
{ \
return VLC_EGENERIC; \
return VLC_EGENERIC; \
}
\
(void)i_shortcut;
\
return VLC_SUCCESS
&& i_shortcut;
\
return VLC_SUCCESS
;
\
} \
} \
struct _u_n_u_s_e_d_
/* the ; gets added */
struct _u_n_u_s_e_d_
/* the ; gets added */
...
...
include/vlc_symbols.h
View file @
92290c9d
...
@@ -9,7 +9,6 @@
...
@@ -9,7 +9,6 @@
# ifdef HAVE_SHARED_LIBVLC
# ifdef HAVE_SHARED_LIBVLC
# error You are not supposed to include this file!
# error You are not supposed to include this file!
# endif
# endif
/*
/*
* This is the big VLC API structure for plugins :
* This is the big VLC API structure for plugins :
* Changing its layout breaks plugin's binary compatibility,
* Changing its layout breaks plugin's binary compatibility,
...
@@ -71,9 +70,9 @@ struct module_symbols_t
...
@@ -71,9 +70,9 @@ struct module_symbols_t
void
(
*
__config_ResetAll_inner
)
(
vlc_object_t
*
);
void
(
*
__config_ResetAll_inner
)
(
vlc_object_t
*
);
module_config_t
*
(
*
config_FindConfig_inner
)
(
vlc_object_t
*
,
const
char
*
);
module_config_t
*
(
*
config_FindConfig_inner
)
(
vlc_object_t
*
,
const
char
*
);
module_t
*
(
*
config_FindModule_inner
)
(
vlc_object_t
*
,
const
char
*
);
module_t
*
(
*
config_FindModule_inner
)
(
vlc_object_t
*
,
const
char
*
);
void
(
*
config_Duplicate_inner
)
(
module_t
*
,
const
module_config_t
*
);
int
(
*
config_Duplicate_inner
)
(
module_t
*
,
const
module_config_t
*
,
size_t
);
void
(
*
config_SetCallbacks_inner
)
(
module_config_t
*
,
module_config_t
*
);
void
(
*
config_SetCallbacks_inner
)
(
module_config_t
*
,
module_config_t
*
,
size_t
);
void
(
*
config_UnsetCallbacks_inner
)
(
module_config_t
*
);
void
(
*
config_UnsetCallbacks_inner
)
(
module_config_t
*
,
size_t
);
int
(
*
__intf_Eject_inner
)
(
vlc_object_t
*
,
const
char
*
);
int
(
*
__intf_Eject_inner
)
(
vlc_object_t
*
,
const
char
*
);
const
iso639_lang_t
*
(
*
GetLang_1_inner
)
(
const
char
*
);
const
iso639_lang_t
*
(
*
GetLang_1_inner
)
(
const
char
*
);
const
iso639_lang_t
*
(
*
GetLang_2T_inner
)
(
const
char
*
);
const
iso639_lang_t
*
(
*
GetLang_2T_inner
)
(
const
char
*
);
...
...
src/libvlc-common.c
View file @
92290c9d
...
@@ -333,7 +333,8 @@ int libvlc_InternalInit( libvlc_int_t *p_libvlc, int i_argc, char *ppsz_argv[] )
...
@@ -333,7 +333,8 @@ int libvlc_InternalInit( libvlc_int_t *p_libvlc, int i_argc, char *ppsz_argv[] )
}
}
p_help_module
->
psz_object_name
=
"help"
;
p_help_module
->
psz_object_name
=
"help"
;
p_help_module
->
psz_longname
=
N_
(
"Help options"
);
p_help_module
->
psz_longname
=
N_
(
"Help options"
);
config_Duplicate
(
p_help_module
,
p_help_config
);
config_Duplicate
(
p_help_module
,
p_help_config
,
sizeof
(
p_help_config
)
/
sizeof
(
p_help_config
[
0
])
);
vlc_object_attach
(
p_help_module
,
libvlc_global
.
p_module_bank
);
vlc_object_attach
(
p_help_module
,
libvlc_global
.
p_module_bank
);
/* End hack */
/* End hack */
...
@@ -1346,7 +1347,6 @@ static void Usage( libvlc_int_t *p_this, char const *psz_module_name )
...
@@ -1346,7 +1347,6 @@ static void Usage( libvlc_int_t *p_this, char const *psz_module_name )
#endif
#endif
vlc_list_t
*
p_list
;
vlc_list_t
*
p_list
;
module_t
*
p_parser
;
module_t
*
p_parser
;
module_config_t
*
p_item
;
char
psz_spaces_text
[
PADDING_SPACES
+
LINE_START
+
1
];
char
psz_spaces_text
[
PADDING_SPACES
+
LINE_START
+
1
];
char
psz_spaces_longtext
[
LINE_START
+
3
];
char
psz_spaces_longtext
[
LINE_START
+
3
];
char
psz_format
[
sizeof
(
FORMAT_STRING
)];
char
psz_format
[
sizeof
(
FORMAT_STRING
)];
...
@@ -1371,8 +1371,9 @@ static void Usage( libvlc_int_t *p_this, char const *psz_module_name )
...
@@ -1371,8 +1371,9 @@ static void Usage( libvlc_int_t *p_this, char const *psz_module_name )
for
(
i_index
=
0
;
i_index
<
p_list
->
i_count
;
i_index
++
)
for
(
i_index
=
0
;
i_index
<
p_list
->
i_count
;
i_index
++
)
{
{
vlc_bool_t
b_help_module
;
vlc_bool_t
b_help_module
;
module_t
*
p_parser
=
(
module_t
*
)
p_list
->
p_values
[
i_index
].
p_object
;
p_parser
=
(
module_t
*
)
p_list
->
p_values
[
i_index
].
p_object
;
module_config_t
*
p_item
,
*
p_end
=
p_parser
->
p_config
+
p_parser
->
confsize
;
if
(
psz_module_name
&&
strcmp
(
psz_module_name
,
if
(
psz_module_name
&&
strcmp
(
psz_module_name
,
p_parser
->
psz_object_name
)
)
p_parser
->
psz_object_name
)
)
...
@@ -1390,13 +1391,12 @@ static void Usage( libvlc_int_t *p_this, char const *psz_module_name )
...
@@ -1390,13 +1391,12 @@ static void Usage( libvlc_int_t *p_this, char const *psz_module_name )
if
(
!
b_advanced
)
if
(
!
b_advanced
)
{
{
for
(
p_item
=
p_parser
->
p_config
;
for
(
p_item
=
p_parser
->
p_config
;
p_item
->
i_type
!=
CONFIG_HINT_END
;
p_item
<
p_end
;
p_item
++
)
p_item
++
)
{
{
if
(
(
p_item
->
i_type
&
CONFIG_ITEM
)
&&
if
(
(
p_item
->
i_type
&
CONFIG_ITEM
)
&&
!
p_item
->
b_advanced
)
break
;
!
p_item
->
b_advanced
)
break
;
}
}
if
(
p_item
->
i_type
==
CONFIG_HINT_END
)
continue
;
}
}
/* Print name of module */
/* Print name of module */
...
@@ -1407,7 +1407,7 @@ static void Usage( libvlc_int_t *p_this, char const *psz_module_name )
...
@@ -1407,7 +1407,7 @@ static void Usage( libvlc_int_t *p_this, char const *psz_module_name )
/* Print module options */
/* Print module options */
for
(
p_item
=
p_parser
->
p_config
;
for
(
p_item
=
p_parser
->
p_config
;
p_item
->
i_type
!=
CONFIG_HINT_END
;
p_item
<
p_end
;
p_item
++
)
p_item
++
)
{
{
char
*
psz_text
,
*
psz_spaces
=
psz_spaces_text
;
char
*
psz_text
,
*
psz_spaces
=
psz_spaces_text
;
...
...
src/libvlc.h
View file @
92290c9d
...
@@ -2213,8 +2213,7 @@ static module_config_t p_help_config[] =
...
@@ -2213,8 +2213,7 @@ static module_config_t p_help_config[] =
.
i_type
=
CONFIG_ITEM_BOOL
,
.
i_type
=
CONFIG_ITEM_BOOL
,
.
psz_name
=
"version"
,
.
psz_name
=
"version"
,
.
psz_text
=
N_
(
"print version information"
)
.
psz_text
=
N_
(
"print version information"
)
},
}
{
.
i_type
=
CONFIG_HINT_END
}
};
};
/*****************************************************************************
/*****************************************************************************
...
...
src/misc/configuration.c
View file @
92290c9d
...
@@ -424,8 +424,6 @@ void __config_PutFloat( vlc_object_t *p_this,
...
@@ -424,8 +424,6 @@ void __config_PutFloat( vlc_object_t *p_this,
module_config_t
*
config_FindConfig
(
vlc_object_t
*
p_this
,
const
char
*
psz_name
)
module_config_t
*
config_FindConfig
(
vlc_object_t
*
p_this
,
const
char
*
psz_name
)
{
{
vlc_list_t
*
p_list
;
vlc_list_t
*
p_list
;
module_t
*
p_parser
;
module_config_t
*
p_item
;
int
i_index
;
int
i_index
;
if
(
!
psz_name
)
return
NULL
;
if
(
!
psz_name
)
return
NULL
;
...
@@ -434,13 +432,14 @@ module_config_t *config_FindConfig( vlc_object_t *p_this, const char *psz_name )
...
@@ -434,13 +432,14 @@ module_config_t *config_FindConfig( vlc_object_t *p_this, const char *psz_name )
for
(
i_index
=
0
;
i_index
<
p_list
->
i_count
;
i_index
++
)
for
(
i_index
=
0
;
i_index
<
p_list
->
i_count
;
i_index
++
)
{
{
p_parser
=
(
module_t
*
)
p_list
->
p_values
[
i_index
].
p_object
;
module_config_t
*
p_item
,
*
p_end
;
module_t
*
p_parser
=
(
module_t
*
)
p_list
->
p_values
[
i_index
].
p_object
;
if
(
!
p_parser
->
i_config_items
)
if
(
!
p_parser
->
i_config_items
)
continue
;
continue
;
for
(
p_item
=
p_parser
->
p_config
;
for
(
p_item
=
p_parser
->
p_config
,
p_end
=
p_item
+
p_parser
->
confsize
;
p_item
->
i_type
!=
CONFIG_HINT_END
;
p_item
<
p_end
;
p_item
++
)
p_item
++
)
{
{
if
(
p_item
->
i_type
&
CONFIG_HINT
)
if
(
p_item
->
i_type
&
CONFIG_HINT
)
...
@@ -494,19 +493,18 @@ module_t *config_FindModule( vlc_object_t *p_this, const char *psz_name )
...
@@ -494,19 +493,18 @@ module_t *config_FindModule( vlc_object_t *p_this, const char *psz_name )
* this module might be unloaded from memory at any time (remember HideModule).
* this module might be unloaded from memory at any time (remember HideModule).
* This is why we need to create an exact copy of the config data.
* This is why we need to create an exact copy of the config data.
*****************************************************************************/
*****************************************************************************/
void
config_Duplicate
(
module_t
*
p_module
,
const
module_config_t
*
p_orig
)
int
config_Duplicate
(
module_t
*
p_module
,
const
module_config_t
*
p_orig
,
size_t
n
)
{
{
int
i
,
j
,
i_lines
=
1
;
int
j
;
const
module_config_t
*
p_item
;
const
module_config_t
*
p_item
,
*
p_end
=
p_orig
+
n
;
/* Calculate the structure length */
/* Calculate the structure length */
p_module
->
i_config_items
=
0
;
p_module
->
i_config_items
=
0
;
p_module
->
i_bool_items
=
0
;
p_module
->
i_bool_items
=
0
;
for
(
p_item
=
p_orig
;
p_item
->
i_type
!=
CONFIG_HINT_END
;
p_item
++
)
for
(
p_item
=
p_orig
;
p_item
<
p_end
;
p_item
++
)
{
{
i_lines
++
;
if
(
p_item
->
i_type
&
CONFIG_ITEM
)
if
(
p_item
->
i_type
&
CONFIG_ITEM
)
{
{
p_module
->
i_config_items
++
;
p_module
->
i_config_items
++
;
...
@@ -519,16 +517,16 @@ void config_Duplicate( module_t *p_module, const module_config_t *p_orig )
...
@@ -519,16 +517,16 @@ void config_Duplicate( module_t *p_module, const module_config_t *p_orig )
}
}
/* Allocate memory */
/* Allocate memory */
p_module
->
p_config
=
(
module_config_t
*
)
malloc
(
sizeof
(
module_config_t
)
p_module
->
p_config
=
(
module_config_t
*
)
calloc
(
n
,
sizeof
(
*
p_orig
)
);
*
i_lines
);
if
(
p_module
->
p_config
==
NULL
)
if
(
p_module
->
p_config
==
NULL
)
{
{
msg_Err
(
p_module
,
"config error: can't duplicate p_config"
);
msg_Err
(
p_module
,
"config error: can't duplicate p_config"
);
return
;
return
VLC_ENOMEM
;
}
}
p_module
->
confsize
=
n
;
/* Do the duplication job */
/* Do the duplication job */
for
(
i
=
0
;
i
<
i_lines
;
i
++
)
for
(
size_t
i
=
0
;
i
<
n
;
i
++
)
{
{
p_module
->
p_config
[
i
]
=
p_orig
[
i
];
p_module
->
p_config
[
i
]
=
p_orig
[
i
];
...
@@ -630,16 +628,12 @@ void config_Duplicate( module_t *p_module, const module_config_t *p_orig )
...
@@ -630,16 +628,12 @@ void config_Duplicate( module_t *p_module, const module_config_t *p_orig )
*****************************************************************************/
*****************************************************************************/
void
config_Free
(
module_t
*
p_module
)
void
config_Free
(
module_t
*
p_module
)
{
{
module_config_t
*
p_item
=
p_module
->
p_config
;
int
i
;
int
i
;
if
(
p_item
==
NULL
)
for
(
size_t
j
=
0
;
j
<
p_module
->
confsize
;
j
++
)
{
{
return
;
module_config_t
*
p_item
=
p_module
->
p_config
+
j
;
}
for
(
;
p_item
->
i_type
!=
CONFIG_HINT_END
;
p_item
++
)
{
if
(
p_item
->
psz_type
)
if
(
p_item
->
psz_type
)
free
(
p_item
->
psz_type
);
free
(
p_item
->
psz_type
);
...
@@ -688,8 +682,11 @@ void config_Free( module_t *p_module )
...
@@ -688,8 +682,11 @@ void config_Free( module_t *p_module )
}
}
}
}
free
(
p_module
->
p_config
);
if
(
p_module
->
p_config
!=
NULL
)
p_module
->
p_config
=
NULL
;
{
free
(
p_module
->
p_config
);
p_module
->
p_config
=
NULL
;
}
}
}
/*****************************************************************************
/*****************************************************************************
...
@@ -699,9 +696,10 @@ void config_Free( module_t *p_module )
...
@@ -699,9 +696,10 @@ void config_Free( module_t *p_module )
* this module might be unloaded from memory at any time (remember HideModule).
* this module might be unloaded from memory at any time (remember HideModule).
* This is why we need to duplicate callbacks each time we reload the module.
* This is why we need to duplicate callbacks each time we reload the module.
*****************************************************************************/
*****************************************************************************/
void
config_SetCallbacks
(
module_config_t
*
p_new
,
module_config_t
*
p_orig
)
void
config_SetCallbacks
(
module_config_t
*
p_new
,
module_config_t
*
p_orig
,
size_t
n
)
{
{
while
(
p_new
->
i_type
!=
CONFIG_HINT_END
)
for
(
size_t
i
=
0
;
i
<
n
;
i
++
)
{
{
p_new
->
pf_callback
=
p_orig
->
pf_callback
;
p_new
->
pf_callback
=
p_orig
->
pf_callback
;
p_new
++
;
p_new
++
;
...
@@ -714,9 +712,9 @@ void config_SetCallbacks( module_config_t *p_new, module_config_t *p_orig )
...
@@ -714,9 +712,9 @@ void config_SetCallbacks( module_config_t *p_new, module_config_t *p_orig )
*****************************************************************************
*****************************************************************************
* We simply undo what we did in config_SetCallbacks.
* We simply undo what we did in config_SetCallbacks.
*****************************************************************************/
*****************************************************************************/
void
config_UnsetCallbacks
(
module_config_t
*
p_new
)
void
config_UnsetCallbacks
(
module_config_t
*
p_new
,
size_t
n
)
{
{
while
(
p_new
->
i_type
!=
CONFIG_HINT_END
)
for
(
size_t
i
=
0
;
i
<
n
;
i
++
)
{
{
p_new
->
pf_callback
=
NULL
;
p_new
->
pf_callback
=
NULL
;
p_new
++
;
p_new
++
;
...
@@ -728,7 +726,7 @@ void config_UnsetCallbacks( module_config_t *p_new )
...
@@ -728,7 +726,7 @@ void config_UnsetCallbacks( module_config_t *p_new )
*****************************************************************************/
*****************************************************************************/
void
__config_ResetAll
(
vlc_object_t
*
p_this
)
void
__config_ResetAll
(
vlc_object_t
*
p_this
)
{
{
int
i_index
,
i
;
int
i_index
;
vlc_list_t
*
p_list
;
vlc_list_t
*
p_list
;
module_t
*
p_module
;
module_t
*
p_module
;
...
@@ -742,7 +740,7 @@ void __config_ResetAll( vlc_object_t *p_this )
...
@@ -742,7 +740,7 @@ void __config_ResetAll( vlc_object_t *p_this )
p_module
=
(
module_t
*
)
p_list
->
p_values
[
i_index
].
p_object
;
p_module
=
(
module_t
*
)
p_list
->
p_values
[
i_index
].
p_object
;
if
(
p_module
->
b_submodule
)
continue
;
if
(
p_module
->
b_submodule
)
continue
;
for
(
i
=
0
;
p_module
->
p_config
[
i
].
i_type
!=
CONFIG_HINT_END
;
i
++
)
for
(
size_t
i
=
0
;
i
<
p_module
->
confsize
;
i
++
)
{
{
if
(
IsConfigIntegerType
(
p_module
->
p_config
[
i
].
i_type
))
if
(
IsConfigIntegerType
(
p_module
->
p_config
[
i
].
i_type
))
p_module
->
p_config
[
i
].
value
.
i
=
p_module
->
p_config
[
i
].
orig
.
i
;
p_module
->
p_config
[
i
].
value
.
i
=
p_module
->
p_config
[
i
].
orig
.
i
;
...
@@ -868,7 +866,7 @@ int __config_LoadConfigFile( vlc_object_t *p_this, const char *psz_module_name )
...
@@ -868,7 +866,7 @@ int __config_LoadConfigFile( vlc_object_t *p_this, const char *psz_module_name )
while
(
fgets
(
line
,
1024
,
file
)
)
while
(
fgets
(
line
,
1024
,
file
)
)
{
{
const
char
*
psz_option_name
,
*
psz_option_value
;
const
char
*
psz_option_name
,
*
psz_option_value
;
module_config_t
*
p_item
;
module_config_t
*
p_item
,
*
p_end
;
if
(
line
[
0
]
==
'['
)
break
;
/* end of section */
if
(
line
[
0
]
==
'['
)
break
;
/* end of section */
...
@@ -895,8 +893,8 @@ int __config_LoadConfigFile( vlc_object_t *p_this, const char *psz_module_name )
...
@@ -895,8 +893,8 @@ int __config_LoadConfigFile( vlc_object_t *p_this, const char *psz_module_name )
}
}
/* try to match this option with one of the module's options */
/* try to match this option with one of the module's options */
for
(
p_item
=
p_parser
->
p_config
;
for
(
p_item
=
p_parser
->
p_config
,
p_end
=
p_item
+
p_parser
->
confsize
;
p_item
->
i_type
!=
CONFIG_HINT_END
;
p_item
<
p_end
;
p_item
++
)
p_item
++
)
{
{
if
(
p_item
->
i_type
&
CONFIG_HINT
)
if
(
p_item
->
i_type
&
CONFIG_HINT
)
...
@@ -1018,7 +1016,6 @@ static int SaveConfigFile( vlc_object_t *p_this, const char *psz_module_name,
...
@@ -1018,7 +1016,6 @@ static int SaveConfigFile( vlc_object_t *p_this, const char *psz_module_name,
{
{
module_t
*
p_parser
;
module_t
*
p_parser
;
vlc_list_t
*
p_list
;
vlc_list_t
*
p_list
;
module_config_t
*
p_item
;
FILE
*
file
;
FILE
*
file
;
char
p_line
[
1024
],
*
p_index2
;
char
p_line
[
1024
],
*
p_index2
;
int
i_sizebuf
=
0
;
int
i_sizebuf
=
0
;
...
@@ -1175,6 +1172,7 @@ static int SaveConfigFile( vlc_object_t *p_this, const char *psz_module_name,
...
@@ -1175,6 +1172,7 @@ static int SaveConfigFile( vlc_object_t *p_this, const char *psz_module_name,
/* Look for the selected module, if NULL then save everything */
/* Look for the selected module, if NULL then save everything */
for
(
i_index
=
0
;
i_index
<
p_list
->
i_count
;
i_index
++
)
for
(
i_index
=
0
;
i_index
<
p_list
->
i_count
;
i_index
++
)
{
{
module_config_t
*
p_item
,
*
p_end
;
p_parser
=
(
module_t
*
)
p_list
->
p_values
[
i_index
].
p_object
;
p_parser
=
(
module_t
*
)
p_list
->
p_values
[
i_index
].
p_object
;
if
(
psz_module_name
&&
strcmp
(
psz_module_name
,
if
(
psz_module_name
&&
strcmp
(
psz_module_name
,
...
@@ -1194,8 +1192,8 @@ static int SaveConfigFile( vlc_object_t *p_this, const char *psz_module_name,
...
@@ -1194,8 +1192,8 @@ static int SaveConfigFile( vlc_object_t *p_this, const char *psz_module_name,
else
else
fprintf
(
file
,
"
\n\n
"
);
fprintf
(
file
,
"
\n\n
"
);
for
(
p_item
=
p_parser
->
p_config
;
for
(
p_item
=
p_parser
->
p_config
,
p_end
=
p_item
+
p_parser
->
confsize
;
p_item
->
i_type
!=
CONFIG_HINT_END
;
p_item
<
p_end
;
p_item
++
)
p_item
++
)
{
{
char
*
psz_key
;
char
*
psz_key
;
...
@@ -1309,8 +1307,6 @@ static int SaveConfigFile( vlc_object_t *p_this, const char *psz_module_name,
...
@@ -1309,8 +1307,6 @@ static int SaveConfigFile( vlc_object_t *p_this, const char *psz_module_name,
int
config_AutoSaveConfigFile
(
vlc_object_t
*
p_this
)
int
config_AutoSaveConfigFile
(
vlc_object_t
*
p_this
)
{
{
vlc_list_t
*
p_list
;
vlc_list_t
*
p_list
;
module_t
*
p_parser
;
module_config_t
*
p_item
;
int
i_index
,
i_count
;
int
i_index
,
i_count
;
/* Check if there's anything to save */
/* Check if there's anything to save */
...
@@ -1319,17 +1315,18 @@ int config_AutoSaveConfigFile( vlc_object_t *p_this )
...
@@ -1319,17 +1315,18 @@ int config_AutoSaveConfigFile( vlc_object_t *p_this )
i_count
=
p_list
->
i_count
;
i_count
=
p_list
->
i_count
;
for
(
i_index
=
0
;
i_index
<
i_count
;
i_index
++
)
for
(
i_index
=
0
;
i_index
<
i_count
;
i_index
++
)
{
{
p_parser
=
(
module_t
*
)
p_list
->
p_values
[
i_index
].
p_object
;
module_t
*
p_parser
=
(
module_t
*
)
p_list
->
p_values
[
i_index
].
p_object
;
module_config_t
*
p_item
,
*
p_end
;
if
(
!
p_parser
->
i_config_items
)
continue
;
if
(
!
p_parser
->
i_config_items
)
continue
;
for
(
p_item
=
p_parser
->
p_config
;
for
(
p_item
=
p_parser
->
p_config
,
p_end
=
p_item
+
p_parser
->
confsize
;
p_item
->
i_type
!=
CONFIG_HINT_END
;
p_item
<
p_end
;
p_item
++
)
p_item
++
)
{
{
if
(
p_item
->
b_autosave
&&
p_item
->
b_dirty
)
break
;
if
(
p_item
->
b_autosave
&&
p_item
->
b_dirty
)
break
;
}
}
if
(
p_item
->
i_type
!=
CONFIG_HINT_END
)
break
;
break
;
}
}
vlc_list_release
(
p_list
);
vlc_list_release
(
p_list
);
vlc_mutex_unlock
(
&
p_this
->
p_libvlc
->
config_lock
);
vlc_mutex_unlock
(
&
p_this
->
p_libvlc
->
config_lock
);
...
@@ -1358,7 +1355,6 @@ int __config_LoadCmdLine( vlc_object_t *p_this, int *pi_argc, char *ppsz_argv[],
...
@@ -1358,7 +1355,6 @@ int __config_LoadCmdLine( vlc_object_t *p_this, int *pi_argc, char *ppsz_argv[],
int
i_cmd
,
i_index
,
i_opts
,
i_shortopts
,
flag
,
i_verbose
=
0
;
int
i_cmd
,
i_index
,
i_opts
,
i_shortopts
,
flag
,
i_verbose
=
0
;
module_t
*
p_parser
;
module_t
*
p_parser
;
vlc_list_t
*
p_list
;
vlc_list_t
*
p_list
;
module_config_t
*
p_item
;
struct
option
*
p_longopts
;
struct
option
*
p_longopts
;
int
i_modules_index
;
int
i_modules_index
;
...
@@ -1456,13 +1452,14 @@ int __config_LoadCmdLine( vlc_object_t *p_this, int *pi_argc, char *ppsz_argv[],
...
@@ -1456,13 +1452,14 @@ int __config_LoadCmdLine( vlc_object_t *p_this, int *pi_argc, char *ppsz_argv[],
for
(
i_modules_index
=
0
;
i_modules_index
<
p_list
->
i_count
;
for
(
i_modules_index
=
0
;
i_modules_index
<
p_list
->
i_count
;
i_modules_index
++
)
i_modules_index
++
)
{
{
module_config_t
*
p_item
,
*
p_end
;
p_parser
=
(
module_t
*
)
p_list
->
p_values
[
i_modules_index
].
p_object
;
p_parser
=
(
module_t
*
)
p_list
->
p_values
[
i_modules_index
].
p_object
;
if
(
!
p_parser
->
i_config_items
)
if
(
!
p_parser
->
i_config_items
)
continue
;
continue
;
for
(
p_item
=
p_parser
->
p_config
;
for
(
p_item
=
p_parser
->
p_config
,
p_end
=
p_item
+
p_parser
->
confsize
;
p_item
->
i_type
!=
CONFIG_HINT_END
;
p_item
<
p_end
;
p_item
++
)
p_item
++
)
{
{
/* Ignore hints */
/* Ignore hints */
...
...
src/misc/modules.c
View file @
92290c9d
...
@@ -1014,7 +1014,7 @@ static int AllocatePluginFile( vlc_object_t * p_this, char * psz_file,
...
@@ -1014,7 +1014,7 @@ static int AllocatePluginFile( vlc_object_t * p_this, char * psz_file,
}
}
else
else
{
{
module_config_t
*
p_item
;
module_config_t
*
p_item
,
*
p_end
;
p_module
=
p_cache_entry
->
p_module
;
p_module
=
p_cache_entry
->
p_module
;
p_module
->
b_loaded
=
VLC_FALSE
;
p_module
->
b_loaded
=
VLC_FALSE
;
...
@@ -1022,8 +1022,8 @@ static int AllocatePluginFile( vlc_object_t * p_this, char * psz_file,
...
@@ -1022,8 +1022,8 @@ static int AllocatePluginFile( vlc_object_t * p_this, char * psz_file,
/* For now we force loading if the module's config contains
/* For now we force loading if the module's config contains
* callbacks or actions.
* callbacks or actions.
* Could be optimized by adding an API call.*/
* Could be optimized by adding an API call.*/
for
(
p_item
=
p_module
->
p_config
;
for
(
p_item
=
p_module
->
p_config
,
p_end
=
p_item
+
p_module
->
confsize
;
p_item
->
i_type
!=
CONFIG_HINT_END
;
p_item
++
)
p_item
<
p_end
;
p_item
++
)
{
{
if
(
p_item
->
pf_callback
||
p_item
->
i_action
)
if
(
p_item
->
pf_callback
||
p_item
->
i_action
)
p_module
=
AllocatePlugin
(
p_this
,
psz_file
);
p_module
=
AllocatePlugin
(
p_this
,
psz_file
);
...
@@ -1809,12 +1809,15 @@ int CacheLoadConfig( module_t *p_module, FILE *file )
...
@@ -1809,12 +1809,15 @@ int CacheLoadConfig( module_t *p_module, FILE *file )
LOAD_IMMEDIATE
(
i_lines
);
LOAD_IMMEDIATE
(
i_lines
);
/* Allocate memory */
/* Allocate memory */
p_module
->
p_config
=
if
(
i_lines
)
(
module_config_t
*
)
malloc
(
sizeof
(
module_config_t
)
*
(
i_lines
+
1
));
if
(
p_module
->
p_config
==
NULL
)
{
{
msg_Err
(
p_module
,
"config error: can't duplicate p_config"
);
p_module
->
p_config
=
return
VLC_ENOMEM
;
(
module_config_t
*
)
calloc
(
i_lines
,
sizeof
(
module_config_t
)
);
if
(
p_module
->
p_config
==
NULL
)
{
msg_Err
(
p_module
,
"config error: can't duplicate p_config"
);
return
VLC_ENOMEM
;
}
}
}
/* Do the duplication job */
/* Do the duplication job */
...
@@ -1901,8 +1904,6 @@ int CacheLoadConfig( module_t *p_module, FILE *file )
...
@@ -1901,8 +1904,6 @@ int CacheLoadConfig( module_t *p_module, FILE *file )
LOAD_IMMEDIATE
(
p_module
->
p_config
[
i
].
pf_callback
);
LOAD_IMMEDIATE
(
p_module
->
p_config
[
i
].
pf_callback
);
}
}
p_module
->
p_config
[
i
].
i_type
=
CONFIG_HINT_END
;
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
error:
error:
...
@@ -2078,13 +2079,14 @@ static void CacheSave( vlc_object_t *p_this )
...
@@ -2078,13 +2079,14 @@ static void CacheSave( vlc_object_t *p_this )
void
CacheSaveConfig
(
module_t
*
p_module
,
FILE
*
file
)
void
CacheSaveConfig
(
module_t
*
p_module
,
FILE
*
file
)
{
{
int
i
,
j
,
i_lines
=
0
;
int
i
,
j
,
i_lines
=
0
;
module_config_t
*
p_item
;
module_config_t
*
p_item
,
*
p_end
;
uint16_t
i_size
;
uint16_t
i_size
;
SAVE_IMMEDIATE
(
p_module
->
i_config_items
);
SAVE_IMMEDIATE
(
p_module
->
i_config_items
);
SAVE_IMMEDIATE
(
p_module
->
i_bool_items
);
SAVE_IMMEDIATE
(
p_module
->
i_bool_items
);
for
(
p_item
=
p_module
->
p_config
;
p_item
->
i_type
!=
CONFIG_HINT_END
;
for
(
p_item
=
p_module
->
p_config
,
p_end
=
p_item
+
p_module
->
confsize
;
p_item
<
p_end
;
p_item
++
)
i_lines
++
;
p_item
++
)
i_lines
++
;
SAVE_IMMEDIATE
(
i_lines
);
SAVE_IMMEDIATE
(
i_lines
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment