Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-1.1
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-1.1
Commits
8e17cc40
Commit
8e17cc40
authored
Jun 05, 2008
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Support for using a custom text domain for configuration strings
parent
64ae2cbf
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
90 additions
and
29 deletions
+90
-29
include/vlc_plugin.h
include/vlc_plugin.h
+22
-8
src/modules/entry.c
src/modules/entry.c
+68
-21
No files found.
include/vlc_plugin.h
View file @
8e17cc40
...
@@ -93,6 +93,7 @@ E_(vlc_entry) ( module_t *p_module );
...
@@ -93,6 +93,7 @@ E_(vlc_entry) ( module_t *p_module );
__VLC_SYMBOL(vlc_entry) ( module_t *p_module ) \
__VLC_SYMBOL(vlc_entry) ( module_t *p_module ) \
{ \
{ \
module_config_t *p_config = NULL; \
module_config_t *p_config = NULL; \
const char *domain = NULL; \
if (vlc_module_set (p_module, VLC_MODULE_NAME, \
if (vlc_module_set (p_module, VLC_MODULE_NAME, \
(const char *)(MODULE_STRING))) \
(const char *)(MODULE_STRING))) \
goto error; \
goto error; \
...
@@ -151,6 +152,8 @@ E_(vlc_entry) ( module_t *p_module );
...
@@ -151,6 +152,8 @@ E_(vlc_entry) ( module_t *p_module );
if (vlc_module_set (p_submodule, VLC_MODULE_NO_UNLOAD)) \
if (vlc_module_set (p_submodule, VLC_MODULE_NO_UNLOAD)) \
goto error;
goto error;
#define set_text_domain( dom ) domain = (dom);
VLC_EXPORT
(
module_t
*
,
vlc_module_create
,
(
vlc_object_t
*
)
);
VLC_EXPORT
(
module_t
*
,
vlc_module_create
,
(
vlc_object_t
*
)
);
VLC_EXPORT
(
module_t
*
,
vlc_submodule_create
,
(
module_t
*
)
);
VLC_EXPORT
(
module_t
*
,
vlc_submodule_create
,
(
module_t
*
)
);
VLC_EXPORT
(
int
,
vlc_module_set
,
(
module_t
*
module
,
int
propid
,
...)
);
VLC_EXPORT
(
int
,
vlc_module_set
,
(
module_t
*
module
,
int
propid
,
...)
);
...
@@ -186,7 +189,7 @@ enum vlc_config_properties
...
@@ -186,7 +189,7 @@ enum vlc_config_properties
VLC_CONFIG_NAME
,
VLC_CONFIG_NAME
,
/* command line name (args=const char *, vlc_callback_t) */
/* command line name (args=const char *, vlc_callback_t) */
VLC_CONFIG_DESC
,
VLC_CONFIG_DESC
_NODOMAIN
,
/* description (args=const char *, const char *) */
/* description (args=const char *, const char *) */
VLC_CONFIG_VALUE
,
VLC_CONFIG_VALUE
,
...
@@ -219,11 +222,11 @@ enum vlc_config_properties
...
@@ -219,11 +222,11 @@ enum vlc_config_properties
VLC_CONFIG_SHORTCUT
,
VLC_CONFIG_SHORTCUT
,
/* one-character (short) command line option name (args=char) */
/* one-character (short) command line option name (args=char) */
VLC_CONFIG_LIST
,
VLC_CONFIG_LIST
_NODOMAIN
,
/* possible values list
/* possible values list
* (args=size_t, const <type> *, const char *const *) */
* (args=size_t, const <type> *, const char *const *) */
VLC_CONFIG_ADD_ACTION
,
VLC_CONFIG_ADD_ACTION
_NODOMAIN
,
/* add value change callback (args=vlc_callback_t, const char *) */
/* add value change callback (args=vlc_callback_t, const char *) */
VLC_CONFIG_OLDNAME
,
VLC_CONFIG_OLDNAME
,
...
@@ -231,6 +234,17 @@ enum vlc_config_properties
...
@@ -231,6 +234,17 @@ enum vlc_config_properties
VLC_CONFIG_SAFE
,
VLC_CONFIG_SAFE
,
/* tag as modifiable by untrusted input item "sources" (args=none) */
/* tag as modifiable by untrusted input item "sources" (args=none) */
VLC_CONFIG_DESC
,
/* description (args=const char *, const char *, const char *) */
VLC_CONFIG_LIST
,
/* possible values list
* (args=const char *, size_t, const <type> *, const char *const *) */
VLC_CONFIG_ADD_ACTION
,
/* add value change callback
* (args=const char *, vlc_callback_t, const char *) */
};
};
/*****************************************************************************
/*****************************************************************************
...
@@ -251,7 +265,7 @@ enum vlc_config_properties
...
@@ -251,7 +265,7 @@ enum vlc_config_properties
#define add_typedesc_inner( type, text, longtext ) \
#define add_typedesc_inner( type, text, longtext ) \
add_type_inner( type ) \
add_type_inner( type ) \
vlc_config_set (p_config, VLC_CONFIG_DESC, \
vlc_config_set (p_config, VLC_CONFIG_DESC,
domain,
\
(const char *)(text), (const char *)(longtext));
(const char *)(text), (const char *)(longtext));
#define add_typeadv_inner( type, text, longtext, advc ) \
#define add_typeadv_inner( type, text, longtext, advc ) \
...
@@ -386,21 +400,21 @@ enum vlc_config_properties
...
@@ -386,21 +400,21 @@ enum vlc_config_properties
vlc_config_set (p_config, VLC_CONFIG_SHORTCUT, (int)(ch));
vlc_config_set (p_config, VLC_CONFIG_SHORTCUT, (int)(ch));
#define change_string_list( list, list_text, list_update_func ) \
#define change_string_list( list, list_text, list_update_func ) \
vlc_config_set (p_config, VLC_CONFIG_LIST, \
vlc_config_set (p_config, VLC_CONFIG_LIST,
domain,
\
(size_t)(sizeof (list) / sizeof (char *)), \
(size_t)(sizeof (list) / sizeof (char *)), \
(const char *const *)(list), \
(const char *const *)(list), \
(const char *const *)(list_text), \
(const char *const *)(list_text), \
list_update_func);
list_update_func);
#define change_integer_list( list, list_text, list_update_func ) \
#define change_integer_list( list, list_text, list_update_func ) \
vlc_config_set (p_config, VLC_CONFIG_LIST, \
vlc_config_set (p_config, VLC_CONFIG_LIST,
domain,
\
(size_t)(sizeof (list) / sizeof (int)), \
(size_t)(sizeof (list) / sizeof (int)), \
(const int *)(list), \
(const int *)(list), \
(const char *const *)(list_text), \
(const char *const *)(list_text), \
list_update_func);
list_update_func);
#define change_float_list( list, list_text, list_update_func ) \
#define change_float_list( list, list_text, list_update_func ) \
vlc_config_set (p_config, VLC_CONFIG_LIST, \
vlc_config_set (p_config, VLC_CONFIG_LIST,
domain,
\
(size_t)(sizeof (list) / sizeof (float)), \
(size_t)(sizeof (list) / sizeof (float)), \
(const float *)(list), \
(const float *)(list), \
(const char *const *)(list_text), \
(const char *const *)(list_text), \
...
@@ -414,7 +428,7 @@ enum vlc_config_properties
...
@@ -414,7 +428,7 @@ enum vlc_config_properties
(double)(minv), (double)(maxv));
(double)(minv), (double)(maxv));
#define change_action_add( pf_action, text ) \
#define change_action_add( pf_action, text ) \
vlc_config_set (p_config, VLC_CONFIG_ADD_ACTION, \
vlc_config_set (p_config, VLC_CONFIG_ADD_ACTION,
domain,
\
(vlc_callback_t)(pf_action), (const char *)(text));
(vlc_callback_t)(pf_action), (const char *)(text));
#define change_internal() \
#define change_internal() \
...
...
src/modules/entry.c
View file @
8e17cc40
...
@@ -252,15 +252,11 @@ int vlc_config_set (module_config_t *restrict item, int id, ...)
...
@@ -252,15 +252,11 @@ int vlc_config_set (module_config_t *restrict item, int id, ...)
break
;
break
;
}
}
case
VLC_CONFIG_DESC
:
case
VLC_CONFIG_DESC
_NODOMAIN
:
{
{
const
char
*
text
=
va_arg
(
ap
,
const
char
*
);
const
char
*
text
=
va_arg
(
ap
,
const
char
*
);
const
char
*
longtext
=
va_arg
(
ap
,
const
char
*
);
const
char
*
longtext
=
va_arg
(
ap
,
const
char
*
);
ret
=
vlc_config_set
(
item
,
VLC_CONFIG_DESC
,
NULL
,
text
,
longtext
);
item
->
psz_text
=
text
?
strdup
(
dgettext
(
PACKAGE
,
text
))
:
NULL
;
item
->
psz_longtext
=
longtext
?
strdup
(
dgettext
(
PACKAGE
,
longtext
))
:
NULL
;
ret
=
0
;
break
;
break
;
}
}
...
@@ -352,8 +348,66 @@ int vlc_config_set (module_config_t *restrict item, int id, ...)
...
@@ -352,8 +348,66 @@ int vlc_config_set (module_config_t *restrict item, int id, ...)
ret
=
0
;
ret
=
0
;
break
;
break
;
case
VLC_CONFIG_LIST_NODOMAIN
:
{
size_t
len
=
va_arg
(
ap
,
size_t
);
if
(
IsConfigIntegerType
(
item
->
i_type
))
{
const
int
*
src
=
va_arg
(
ap
,
const
int
*
);
const
char
*
const
*
text
=
va_arg
(
ap
,
const
char
*
const
*
);
ret
=
vlc_config_set
(
item
,
VLC_CONFIG_LIST
,
NULL
,
len
,
src
,
text
);
}
else
if
(
IsConfigStringType
(
item
->
i_type
))
{
const
char
*
const
*
src
=
va_arg
(
ap
,
const
char
*
const
*
);
const
char
*
const
*
text
=
va_arg
(
ap
,
const
char
*
const
*
);
ret
=
vlc_config_set
(
item
,
VLC_CONFIG_LIST
,
NULL
,
len
,
src
,
text
);
}
break
;
}
case
VLC_CONFIG_ADD_ACTION_NODOMAIN
:
{
vlc_callback_t
cb
=
va_arg
(
ap
,
vlc_callback_t
);
const
char
*
name
=
va_arg
(
ap
,
const
char
*
);
ret
=
vlc_config_set
(
item
,
VLC_CONFIG_ADD_ACTION
,
NULL
,
cb
,
name
);
break
;
}
case
VLC_CONFIG_OLDNAME
:
{
const
char
*
oldname
=
va_arg
(
ap
,
const
char
*
);
item
->
psz_oldname
=
oldname
?
strdup
(
oldname
)
:
NULL
;
ret
=
0
;
break
;
}
case
VLC_CONFIG_SAFE
:
item
->
b_safe
=
true
;
ret
=
0
;
break
;
case
VLC_CONFIG_DESC
:
{
const
char
*
domain
=
va_arg
(
ap
,
const
char
*
);
const
char
*
text
=
va_arg
(
ap
,
const
char
*
);
const
char
*
longtext
=
va_arg
(
ap
,
const
char
*
);
if
(
domain
==
NULL
)
domain
=
PACKAGE
;
item
->
psz_text
=
text
?
strdup
(
dgettext
(
domain
,
text
))
:
NULL
;
item
->
psz_longtext
=
longtext
?
strdup
(
dgettext
(
domain
,
longtext
))
:
NULL
;
ret
=
0
;
break
;
}
case
VLC_CONFIG_LIST
:
case
VLC_CONFIG_LIST
:
{
{
const
char
*
domain
=
va_arg
(
ap
,
const
char
*
);
size_t
len
=
va_arg
(
ap
,
size_t
);
size_t
len
=
va_arg
(
ap
,
size_t
);
char
**
dtext
=
malloc
(
sizeof
(
char
*
)
*
(
len
+
1
));
char
**
dtext
=
malloc
(
sizeof
(
char
*
)
*
(
len
+
1
));
...
@@ -406,12 +460,15 @@ int vlc_config_set (module_config_t *restrict item, int id, ...)
...
@@ -406,12 +460,15 @@ int vlc_config_set (module_config_t *restrict item, int id, ...)
break
;
break
;
/* Copy textual descriptions */
/* Copy textual descriptions */
if
(
domain
==
NULL
)
domain
=
PACKAGE
;
const
char
*
const
*
text
=
va_arg
(
ap
,
const
char
*
const
*
);
const
char
*
const
*
text
=
va_arg
(
ap
,
const
char
*
const
*
);
if
(
text
!=
NULL
)
if
(
text
!=
NULL
)
{
{
for
(
size_t
i
=
0
;
i
<
len
;
i
++
)
for
(
size_t
i
=
0
;
i
<
len
;
i
++
)
dtext
[
i
]
=
dtext
[
i
]
=
text
[
i
]
?
strdup
(
dgettext
(
PACKAGE
,
text
[
i
]))
:
NULL
;
text
[
i
]
?
strdup
(
dgettext
(
domain
,
text
[
i
]))
:
NULL
;
dtext
[
len
]
=
NULL
;
dtext
[
len
]
=
NULL
;
item
->
ppsz_list_text
=
dtext
;
item
->
ppsz_list_text
=
dtext
;
...
@@ -430,6 +487,7 @@ int vlc_config_set (module_config_t *restrict item, int id, ...)
...
@@ -430,6 +487,7 @@ int vlc_config_set (module_config_t *restrict item, int id, ...)
case
VLC_CONFIG_ADD_ACTION
:
case
VLC_CONFIG_ADD_ACTION
:
{
{
const
char
*
domain
=
va_arg
(
ap
,
const
char
*
);
vlc_callback_t
cb
=
va_arg
(
ap
,
vlc_callback_t
),
*
tabcb
;
vlc_callback_t
cb
=
va_arg
(
ap
,
vlc_callback_t
),
*
tabcb
;
const
char
*
name
=
va_arg
(
ap
,
const
char
*
);
const
char
*
name
=
va_arg
(
ap
,
const
char
*
);
char
**
tabtext
;
char
**
tabtext
;
...
@@ -448,8 +506,10 @@ int vlc_config_set (module_config_t *restrict item, int id, ...)
...
@@ -448,8 +506,10 @@ int vlc_config_set (module_config_t *restrict item, int id, ...)
break
;
break
;
item
->
ppsz_action_text
=
tabtext
;
item
->
ppsz_action_text
=
tabtext
;
if
(
domain
==
NULL
)
domain
=
PACKAGE
;
if
(
name
)
if
(
name
)
tabtext
[
item
->
i_action
]
=
strdup
(
dgettext
(
PACKAGE
,
name
));
tabtext
[
item
->
i_action
]
=
strdup
(
dgettext
(
domain
,
name
));
else
else
tabtext
[
item
->
i_action
]
=
NULL
;
tabtext
[
item
->
i_action
]
=
NULL
;
tabtext
[
item
->
i_action
+
1
]
=
NULL
;
tabtext
[
item
->
i_action
+
1
]
=
NULL
;
...
@@ -458,19 +518,6 @@ int vlc_config_set (module_config_t *restrict item, int id, ...)
...
@@ -458,19 +518,6 @@ int vlc_config_set (module_config_t *restrict item, int id, ...)
ret
=
0
;
ret
=
0
;
break
;
break
;
}
}
case
VLC_CONFIG_OLDNAME
:
{
const
char
*
oldname
=
va_arg
(
ap
,
const
char
*
);
item
->
psz_oldname
=
oldname
?
strdup
(
oldname
)
:
NULL
;
ret
=
0
;
break
;
}
case
VLC_CONFIG_SAFE
:
item
->
b_safe
=
true
;
ret
=
0
;
break
;
}
}
va_end
(
ap
);
va_end
(
ap
);
...
...
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